❤️ Helfen Sie noch heute, unser LibreOffice Forum zu erhalten! ❤️
Unterstützen Sie das LibreOffice-Forum und helfen Sie uns, unser Ziel für 2025 zu erreichen!

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱


❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 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: 909
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 und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten