🍀 Das LibreOffice Forum braucht HEUTE Ihre Hilfe! 🍀
❤️ Spenden Sie jetzt und sichern Sie die Zukunft unseres LibreOffice-Forums ❤️
Ihre Spende hilft, die Community offen, werbefrei (bei Registrierung) und lebendig zu halten. Vielen lieben Dank!

🙏 DANKE >> << DANKE 🙏

>> Das LibreOffice-Forum lebt von Ihnen – und von vielen Experten, die freiwillig und kostenlos ihr Wissen teilen.<<
Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet.

Java Makro in Libreoffice calc erstellen!

CALC ist die Tabellenkalkulation, die Sie immer wollten.
Antworten
rustyoldguy
Beiträge: 34
Registriert: Mo 24. Feb 2020, 19:05
Wohnort: Amberg in der Oberpfalz

Java Makro in Libreoffice calc erstellen!

Beitrag von rustyoldguy » Fr 13. Mär 2020, 20:40

Hallo Leute!

Bisher habe ich meine Makros in BASIC geschrieben., Nun möchte ich aber welche in Java
implementieren. Momentan ist die Open JDK 13.0.2 auf meinem Linux installiert.
LibreOffice Version ist 6.4.1.1

Ich habe mit EXTRAS->MAKROS->Makros_verwalten->JavaScript
zuerst eine Bibliothek erstellt, dann ein Makro un unten meine Funktion dazugeschrieben.
Gibt aber eine Fehlermeldung:
Beim Makro

Code: Alles auswählen

/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */
// Hello World in JavaScript
// Import standard OpenOffice.org API classes. For more information on
// these classes and the OpenOffice.org API, see the OpenOffice.org
// Developers Guide at:
// https://api.libreoffice.org/

importClass(Packages.com.sun.star.uno.UnoRuntime);
importClass(Packages.com.sun.star.text.XTextDocument);
importClass(Packages.com.sun.star.text.XText);
importClass(Packages.com.sun.star.text.XTextRange);
importClass(Packages.com.sun.star.frame.XModel);

// Import XScriptContext class. An instance of this class is available
// to all JavaScript scripts in the global variable "XSCRIPTCONTEXT". This
// variable can be used to access the document for which this script
// was invoked.

// Methods available are:

//   XSCRIPTCONTEXT.getDocument() returns XModel
//   XSCRIPTCONTEXT.getInvocationContext() returns XScriptInvocationContext or NULL
//   XSCRIPTCONTEXT.getDesktop() returns XDesktop
//   XSCRIPTCONTEXT.getComponentContext() returns XComponentContext

// For more information on using this class see the scripting
// developer guides at:

//   https://api.libreoffice.org/docs/DevelopersGuide/ScriptingFramework/ScriptingFramework.xhtml


oDoc = UnoRuntime.queryInterface(XModel,XSCRIPTCONTEXT.getInvocationContext());
if ( !oDoc )
  oDoc = XSCRIPTCONTEXT.getDocument();
xTextDoc = UnoRuntime.queryInterface(XTextDocument,oDoc);
xText = xTextDoc.getText();
xTextRange = xText.getEnd();
xTextRange.setString( "Hello World (in JavaScript)" );



Bleibt mir der Rhino JavaScript Debugger
bei Zeile 52 hängen(xText = xTextDoc.getText(); ):

Cannot read properly "getText" from null
Die Java-Laufzeitumgebung habe ich ohne Parameter gestartet.
Was habe ich falsch gemacht?

Wanderer
* LO-Experte *
Beiträge: 914
Registriert: Di 11. Feb 2014, 20:03
Wohnort: Berlin

Re: Java Makro in Libreoffice calc erstellen!

Beitrag von Wanderer » Fr 13. Mär 2020, 21:52

Du wirfst Java und Javascript durcheinander.

Aber da Dein Script wohl tatsächlich Javascript ist, ist das nicht so kritisch.

Ich habe Javascript auSserhalb eines Browsers allerdings nicht benutzt, so dass Du auf jemanden warten musst, der das in AOO schon probiert hat...

Mfg, Jörn
LO 6.0.7 (32Bit) Win8.1 Pro 32 Bit/ LO 6.3.2 Win10 64Bit / LO 6.0.7 Win7 Pro 64 Bit


An alle, die das LibreOffice-Forum gern nutzen:
Bitte beteiligen Sie sich mit 7 Euro pro Monat und helfen uns bei unserem Budget für das laufende.
Einfach per Kreditkarte oder PayPal. Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet.



❤️ Vielen lieben Dank für Ihre Unterstützung ❤️

Antworten