#include <Inventor/Qt/SoQt.h>
Public Types | |
enum | FatalErrors { NO_OPENGL_CANVAS = 0, INTERNAL_ASSERT, UNSPECIFIED_ERROR } |
Public Methods | |
typedef void | FatalErrorCB (const SbString errmsg, SoQt::FatalErrors errcode, void *userdata) |
Static Public Methods | |
QWidget * | init (const char *appname, const char *classname="SoQt") |
QWidget * | init (int argc, char **argv, const char *appname, const char *classname="SoQt") |
void | init (QWidget *toplevelwidget) |
void | mainLoop (void) |
void | exitMainLoop (void) |
QWidget * | getTopLevelWidget (void) |
QWidget * | getShellWidget (const QWidget *w) |
void | show (QWidget *const widget) |
void | hide (QWidget *const widget) |
void | setWidgetSize (QWidget *const widget, const SbVec2s size) |
SbVec2s | getWidgetSize (const QWidget *widget) |
void | createSimpleErrorDialog (QWidget *widget, const char *dialogTitle, const char *errorStr1, const char *errorStr2=NULL) |
void | getVersionInfo (int *major=NULL, int *minor=NULL, int *micro=NULL) |
const char * | getVersionString (void) |
FatalErrorCB * | setFatalErrorHandler (SoQt::FatalErrorCB *cb, void *userdata) |
Static Protected Methods | |
SbBool | isDebugLibrary (void) |
SbBool | isCompatible (unsigned int major, unsigned int minor) |
SoQtABIType | getABIType (void) |
void | abort (SoQtABIError error) |
This is the "application-wide" class with solely static methods handling initialization and event processing tasks. You must use this class in any application built on top of the SoQt library. Typical usage is as follows (complete application code):
#include <Inventor/Qt/SoQt.h> #include <Inventor/Qt/viewers/SoQtExaminerViewer.h> #include <Inventor/nodes/SoCube.h> int main(int argc, char **argv) { // Initialize SoQt and Open Inventor libraries. This returns a main // window to use. QWidget * mainwin = SoQt::init(argv[0]); // Make a dead simple scene graph, only containing a single cube. SoCube * cube = new SoCube; // Use one of the convenient viewer classes. SoQtExaminerViewer * eviewer = new SoQtExaminerViewer(mainwin); eviewer->setSceneGraph(cube); eviewer->show(); // Pop up the main window. SoQt::show(mainwin); // Loop until exit. SoQt::mainLoop(); return 0; }
|
|
This function initializes the SoQt library. The returned QWidget * is a toplevel shell widget for the application, which can be used as a shell for the main component. This method is provided for easier porting / compatibility with the original SGI Inventor InventorXt library. It just adds dummy argc and argv arguments and calls the SoQt::init() method below. |
|
This is the event dispatch loop. It doesn't return until QApplication::quit() or QApplication::exit() is called (which is also done automatically by Qt whenever the user closes an application's main widget). |
|
This funtcion will make the main event loop finish looping. NOTE: exitMainLoop() is not present in the original API for SGI's InventorXt library. |
|
Returns a pointer to the Qt QWidget which is the main widget for the application. When this widget gets closed, SoQt::mainLoop() will return (unless the close event is caught by the user).
|
|
Returns a pointer to the Qt QWidget which is the top level widget for the given QWidget w. This is just a convenience function provided for easier porting of Open Inventor applications based on SoXt components, as you can do the same thing by calling the QWidget::topLevelWidget() method directly on w.
|
|
This method is provided for easier porting/compatibility with the Open Inventor SoXt component classes. It will call QWidget::show() and QWidget::raise() on the provided widget pointer.
|
|
This method is provided for easier porting/compatibility with the Open Inventor SoXt component classes. It will call QWidget::hide() on the provided widget pointer.
|
|
This method is provided for easier porting of applications based on the Open Inventor SoXt component classes. It will call QWidget::resize() on the provided w widget pointer.
|
|
This method is provided for easier porting/compatibility with the Open Inventor SoXt component classes. It will do the same as calling QWidget::size() (except that we're returning an SbVec2s).
|
|
This will pop up an error dialog. It's just a simple wrap-around for the Qt QMessageBox::warning() call, provided for easier porting from applications using the Open Inventor SoXt component classes. If widget is NULL, the dialog will be modal for the whole application (all windows will be blocked for input). If not, only the window for the given widget will be blocked. dialogTitle is the title of the dialog box. errorStr1 and errorStr2 contains the text which will be shown in the dialog box. There will only be a single "Ok" button for the user to press. |
|
This method will fill in the integers pointed to by the arguments with the corresponding part of the version release number of the SoQt library.
A This method is not part of the original InventorXt API from SGI. |
|
This method returns a string containing the version id of the library. This method is not part of the original InventorXt API from SGI. |
|
An application function callback for handling fatal errors should be of this type. The first argument is an error message in English describing the details of the error. The second argument is an error code used so the application can identify specific conditions. The third argument is the userdata pointer passed in to SoQt::setFatalErrorHandler(). |
|
Set up a callback to invoke in the case of unexpected fatal error conditions within the SoQt library. Almost any error condition within the library is handled in a robust way through return values indicating errors for the offending calls, but there are a few cases that are impossible to handle without seriously crippling the functionality. (One example is if we fail to find any way of making a valid OpenGL canvas. This is an indication that something is seriously wrong on the end-user's system, and the SoQt library will not work properly.) In the case of a fatal error, it is expected that the given application callback function communicates the problem to the end-user and then either exits the application or at least refrains from using any part of the SoQt library. If no callback is explicitly set up by the application, the SoQt library will display an error message to the end-user and then exit the application.
When setting a callback, this method returns a pointer to the previous callback function, or (This is an extension versus the original SGI InventorXt library API.) On a related note, be aware that the end-user will still be notified about non-fatal errors and warning messages through a dialog box. If you want to handle these yourself, or if you don't want your end-user to see any of these non-critical messages, you will also need to install an error handler callback function on the Coin library itself:
SoDebugError::setHandlerCallback(myErrorHandlerCB, myCBUserData); (Please also see the documentation of SoDebugError::setHandlerCallback().) |
|
Returns This method was not part of the original SGI InventorXt library, but is an extension specific to the Coin project. |
|
Returns This method was not part of the original SGI InventorXt library, but is an extension specific to the Coin project. |
|
Returns an indication on how the library was compiled: as a dynamic library, or as a static library. This method was not part of the original SGI InventorXt library, but is an extension specific to the Coin project. |
|
Abort the application due to some kind of mismatch in the ABI settings / configuration. This should hopefully help application programmers avoid shooting themselves in the foot by controlling certain run-time parameters in the client application versus what is expected by the SoQt library. If you're an application programmer, it is very likely that you only need to consider this an internal library method. This method was not part of the original SGI InventorXt library, but is an extension specific to the Coin project. |