Qt Jambi: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
 
(I updated this fully outdated description of QtJambi to its current situation.)
 
(9 intermediate revisions by 4 users not shown)
Line 1: Line 1:
=Qt Jambi=
__NOTOC__


This is a community maintained project (‘qtjambi-community’) that provides Java language bindings to the Qt <span class="caps">API</span>s. The bindings are generated by inspection of the C++ header files of the Qt implementation then emitting code to provide the necessary <span class="caps">JNI</span> (Java Native Interface) and *.java files to provide linkage to Java. An application programmer using Qt Jambi would simply add the *.jar files to their Java project to be able to develop and deploy their application.
''QtJambi'' is a community-maintained open-source project that provides Java language bindings to the Qt APIs. The bindings are generated by inspection of the C++ header files of the Qt implementation then emitting code to provide the necessary JNI (Java Native Interface) and ''.java'' files to provide linkage to Java. An application programmer using Qt Jambi would simply add the coresponding Java libraries (''.jar'' files) to their Java project to be able to develop and deploy their application.


The bindings implement such things as signal/slot mechanics for Java and cross-thread marshaling of an event driven programming model. Indeed the <span class="caps">API</span> presented to the Java programmer is very similar to the C++ <span class="caps">API</span>s so your knowledge of C++ can largely be transferred to Java. These alternative programming models maybe considered a new and refreshing choice for application developers looking for an alternative to the strict static type programming patterns employed by other Java UI toolkits. Qt Jambi makes use of Java reflection and can integrate with the QMetaObject system (that provides similar reflection mechanism to C++). However it does not preclude the use of any Java patterns from your application design Qt Jambi provides additional ways to program java.
Example:<syntaxhighlight lang="java">
import io.qt.widgets.*;
public class Test {
public static void main(String[] args) {
QApplication.initialize(args);
QMessageBox.information(null, "QtJambi", "Hello World!");
QApplication.shutdown();
}
}
</syntaxhighlight>The bindings implement typical C++-Qt features for Java like:


There is much overlap with some Qt modules with already existing Java <span class="caps">API</span>s and 3rd party libraries. Qt Jambi does not inhibit or restrict the implementation of a feature you choose to use. Some of the strengths of Qt to Java are in the cross-platform UI toolkit, the programming model, UI scripting support, embedded web browser support.
* signal/slot mechanism
* meta object properties
* thread-affinity, multithreading, cross-thread marshaling
* resource management
* internationalization
* interfaces
* containers
* function pointers
* QML / Java interoperability
* and more


The qtjambi-community source project integrates with all Qt versions between 4.5 and 4.8+, this includes, 4.6 and 4.7. Work on Qt5 is planned but not until the release of 5.1 where Qt on the desktop will get attention. One aspect of the project is that due to the generation technique bug fixes applied to the project can still be used with all supported Qt versions, there is no need to back-port such fixes. Simply rebuild the project against the version of Qt you wish to use.
Indeed the API presented to the Java programmer is very similar to the C++ APIs so your knowledge of C++ can largely be transferred to Java. These alternative programming models maybe considered a new and refreshing choice for application developers looking for an alternative to the strict static type programming patterns employed by other Java UI toolkits. Qt Jambi makes use of Java reflection and can integrate with the QMetaObject system (that provides similar reflection mechanism to C+)''.''


Another feature of the project is that it is possible to reuse your custom C++ QWidget’s and other QPlugins with Qt Jambi. If your objects expose QMetaObject they may simply work as the java bindings are able to invoke and integrate with QMetaObject. Alternatively you can use the generator (provided in the Qt Jambi project) to expose Java <span class="caps">API</span> bindings for your custom plugins, an example of this is provided in the project sources. This allows you to combine the benefit of C++ performance in areas where it is needed with the rapid application development enjoyed by Java developers.


The Community website for Qt Jambi can be found at [http://qt-jambi.org Qt Jambi Community’s website.] ''[qt-jambi.org]''
There is much overlap with some Qt modules with already existing Java APIs and 3rd party libraries. Qt Jambi does not inhibit or restrict the implementation of a feature you choose to use. However, the combination of Qt and other UI toolkits in the same application is technically limited. Some of the strengths of Qt to Java are in the cross-platform UI toolkit, the programming model, UI scripting support, embedded web browser support.


The Community bug tracker: [http://redmine.smar.fi/projects/qtjambi/issues Qt Jambi Community bug tracker] ''[redmine.smar.fi]''


The Community patch submission: [http://gerrit.smar.fi/#/q/status:open+project:qtjambi-community,n,z Qt Jambi Community gerrit] ''[gerrit.smar.fi]''
Another feature of the project is that it is possible to reuse your custom C++ QWidget's and other QPlugins with Qt Jambi. If your objects expose QMetaObject they may simply work as the java bindings are able to invoke and integrate with QMetaObject. Alternatively you can use the generator (provided in the Qt Jambi project) to expose Java API bindings for your custom C++ library. This allows you to combine the benefit of C++ performance in areas where it is needed with the rapid application development enjoyed by Java developers.


==Qt Jambi past==
==Qt Jambi past==


Before March 2009 the project (‘qt-jambi’) was maintained and released by Trolltech, their latest release was Qt Jambi 4.5.2_01 based on a port of Qt 4.5.2. This is last version by the Qt team (based at Trolltech). When Nokia purchased Trolltech the Qt Jambi project was not put into the future road map so the work was spun off into the open source project. The source code project that is called ‘qt-jambi’ is from this pre March 2009 era and does not support any version of Qt 4.7 or later.
Before March 2009 the project ('qt-jambi') was maintained and released by Trolltech, their latest release was Qt Jambi 4.5.2_01 based on a port of Qt 4.5.2. This is last version by the Qt team (based at Trolltech). When Nokia purchased Trolltech the Qt Jambi project was not put into the future road map so the work was spun off into the open source project. The source code project that is called 'qt-jambi' is from this pre March 2009 era and does not support any version of Qt 4.7 or later. The successor open source project 'https://github.com/qtjambi/qtjambi<nowiki/>' continued support for all Qt versions between 4.5 and 4.8.


==Binaries==
==Binaries==


[http://qt-jambi.org/downloads Qt Jambi Community Releases] ''[qt-jambi.org]''
[https://github.com/OmixVisualization/qtjambi/releases QtJambi Releases]
 
==Old Binaries (not maintained since March 2009)==
 
[http://get.qt.nokia.com/qtjambi/source/qtjambi-win32-lgpl-4.5.2_01.zip Qt Jambi 4.5.2_01Binary for Windows 32-bit] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-win64-lgpl-4.5.2_01.zip Qt Jambi 4.5.2_01Binary for Windows 64-bit] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-mac-lgpl-4.5.2_01.tar.gz Qt Jambi 4.5.2_01Binary for Mac] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-linux32-lgpl-4.5.2_01.tar.gz Qt Jambi 4.5.2_01Binary for Linux/X11 32-bit] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-linux64-lgpl-4.5.2_01.tar.gz Qt Jambi 4.5.2_01Binary for Linux/X11 64-bit] ''[get.qt.nokia.com]''
 
==Old Eclipse Integation (not maintained since March 2009)==
 
[http://get.qt.nokia.com/qtjambi/source/qtjambi-eclipse-integration-linux32-4.5.2_01.tar.gz Qt Jambi 4.5.2_01 for Linux/X11 32-bit] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-eclipse-integration-win32-4.5.2_01.zip Qt Jambi 4.5.2_01 for Windows] ''[get.qt.nokia.com]''
 
==Old Source Package (not maintained since March 2009)==
 
[http://get.qt.nokia.com/qtjambi/source/qtjambi-src-lgpl-4.5.2_01.tar.gz Qt Jambi 4.5.2_01 Source Package] ''[get.qt.nokia.com]''<br />[http://get.qt.nokia.com/qtjambi/source/qtjambi-src-lgpl-4.5.2_01.zip Qt Jambi 4.5.2_01 Source Package] ''[get.qt.nokia.com]''


==Repository==
==Repository==


http://qt.gitorious.org/qt-jambi/qtjambi-community ''[qt.gitorious.org]'' ''this source tree is actively being developed''
https://github.com/OmixVisualization/qtjambi ''this source tree is actively being developed''
 
http://qt.gitorious.org/qt-jambi/qt-jambi ''[qt.gitorious.org]'' ''this source tree has not been maintained since March 2009''
 
==Ubuntu (<span class="caps">PPA</span> from Launchpad)==
 
It is best to read download and install instructions in <span class="caps">PPA</span> description at:
 
[http://launchpad.net/~qtjambi-community/+archive/libqtjambi-snapshots Qt Jambi Snaphosts for Ubuntu] ''[launchpad.net]''
 
This tries to cover all recent Ubuntu releases and <span class="caps">LTS</span> releases that are compatible with Qt Jambi project.
 
==<span class="caps">OBS</span> (OpenSuSE build system, including Fedora/Red Hat/CentOS and <span class="caps">SLS</span>/OpenSuSE)==
 
[https://build.opensuse.org/package/show?package=qtjambi-snapshots&project=home:dlmiles:qtjambi-community Qt Jambi Snapshots for Linux] ''[build.opensuse.org]''
 
See <span class="caps">OBS</span> wiki and documentation for how to add a custom repository to your distribution. Then you can download, update and install via your Linux package manager.
 
==Mailing List==
 
[http://lists.qt.nokia.com/mailman/listinfo/qt-jambi-interest Qt-jambi-interest Archives and Subscription] ''[lists.qt.nokia.com]''


==See also==
==See also==


This page describes the Java bindings. There is also QtScript which is the JavaScript bindings. Similar sounding technologies, but very different <span class="smiley">:)</span><br /> See http://qt.gitorious.org/qt-labs/qtscriptgenerator ''[qt.gitorious.org]'' for the JavaScript bindings.
This page describes the Java bindings. There is also QtScript which is the JavaScript bindings. Similar sounding technologies, but very different :)
 
===Categories:===
 
* [[:Category:LanguageBindings|LanguageBindings]]
** [[:Category:LanguageBindings::QtJambi|QtJambi]]

Latest revision as of 08:13, 10 May 2021


QtJambi is a community-maintained open-source project that provides Java language bindings to the Qt APIs. The bindings are generated by inspection of the C++ header files of the Qt implementation then emitting code to provide the necessary JNI (Java Native Interface) and .java files to provide linkage to Java. An application programmer using Qt Jambi would simply add the coresponding Java libraries (.jar files) to their Java project to be able to develop and deploy their application.

Example:

import io.qt.widgets.*;
public class Test {
	public static void main(String[] args) {
		QApplication.initialize(args);
		QMessageBox.information(null, "QtJambi", "Hello World!");
		QApplication.shutdown();
	}
}

The bindings implement typical C++-Qt features for Java like:

  • signal/slot mechanism
  • meta object properties
  • thread-affinity, multithreading, cross-thread marshaling
  • resource management
  • internationalization
  • interfaces
  • containers
  • function pointers
  • QML / Java interoperability
  • and more

Indeed the API presented to the Java programmer is very similar to the C++ APIs so your knowledge of C++ can largely be transferred to Java. These alternative programming models maybe considered a new and refreshing choice for application developers looking for an alternative to the strict static type programming patterns employed by other Java UI toolkits. Qt Jambi makes use of Java reflection and can integrate with the QMetaObject system (that provides similar reflection mechanism to C+).


There is much overlap with some Qt modules with already existing Java APIs and 3rd party libraries. Qt Jambi does not inhibit or restrict the implementation of a feature you choose to use. However, the combination of Qt and other UI toolkits in the same application is technically limited. Some of the strengths of Qt to Java are in the cross-platform UI toolkit, the programming model, UI scripting support, embedded web browser support.


Another feature of the project is that it is possible to reuse your custom C++ QWidget's and other QPlugins with Qt Jambi. If your objects expose QMetaObject they may simply work as the java bindings are able to invoke and integrate with QMetaObject. Alternatively you can use the generator (provided in the Qt Jambi project) to expose Java API bindings for your custom C++ library. This allows you to combine the benefit of C++ performance in areas where it is needed with the rapid application development enjoyed by Java developers.

Qt Jambi past

Before March 2009 the project ('qt-jambi') was maintained and released by Trolltech, their latest release was Qt Jambi 4.5.2_01 based on a port of Qt 4.5.2. This is last version by the Qt team (based at Trolltech). When Nokia purchased Trolltech the Qt Jambi project was not put into the future road map so the work was spun off into the open source project. The source code project that is called 'qt-jambi' is from this pre March 2009 era and does not support any version of Qt 4.7 or later. The successor open source project 'https://github.com/qtjambi/qtjambi' continued support for all Qt versions between 4.5 and 4.8.

Binaries

QtJambi Releases

Repository

https://github.com/OmixVisualization/qtjambi this source tree is actively being developed

See also

This page describes the Java bindings. There is also QtScript which is the JavaScript bindings. Similar sounding technologies, but very different :)