This document gives some basic information about making a plugin to 3dmod and contains the documentation of the functions in 3dmod that are normally accessible from plugins.
Definitions for controls.
Control callbacks
Methods in the DialogManager class.
void DLL_EX_IM adjustGeometryAndShow(QWidget *widget, int dlgClass,
bool doSize = true)
void add(QWidget *widget, int dlgClass = IMODV_DIALOG,
int dlgType = UNKNOWN_TYPE, int ctrlId = -1)
void remove(QWidget *widget)
QWidget *parent(int dlgClass)
./setup (cd libimod ; make) (cd libcfshr ; make) (cd libdiaqt ; make) make plugsIn Linux, setup will run with no Fortran compiler and libraries should build with no problem. On Mac OS X, setup will run with no Fortran compiler, although this will require "setup -c gnu" at least on the Intel Mac. In Windows, setup will run with no Fortran compiler but you will probably need the Intel C++ compiler. If you need to access any other C libraries from your plugin, you would need to build them as well. "make clibs" builds all C libraries. If you need to build libiimod, you will need a tiff library: in Mac OS X, this would be installed in the system; on Windows, you would need libtiff.lib in buildlib. See how much easier Linux is?
Beadfixer example. The plugin in IMOD/plugs/beadfix is an old version of the Bead Fixer that was retained to test the ability to build and run plugins, and now serves as an example of a plugin. It is not ideal because it has much more functionality than is needed to illustrate the various features of a plugin. You can concentrate on the implementation of the generic plugin functions in the beginning of the file and ignore most of the class implementation. The functional components do provide examples of how to access and manipulate model structures. It has been updated in IMOD 4.10 to make the plugin be contained in a DockingDialog, which is appropriate for it because it does not contain variable-sized elements like tables. For a dialog where the user may want to change the size, you can use the old version of this plugin in IMOD 4.9, or look at the Stereology or Name Wizard plugins. There is one major deficiency in this example; it has not been updated to show the proper handling of calls to the undo/redo module. If your plugin modifies the model, you should try to make these calls, as documented below. For examples, you can look in corresponding places in the current beadfix.cpp in the imod directory and in other places in the 3dmod code (grep on "undo").
Public versus Private Structures. The beadfixer example is set up to access the model only by passing pointers to functions that operate on the underlying structures, rather than by accessing structure members directly. This method of defining structures as private was set up by Jim Kremer when he first developed the plugin interface; it has been retained but not extended to cover some new model structures or other structures in the IMOD libraries. It is possible to define a flag to eliminate the private structures and allow access to structure members. The advantages of keeping the structures private are 1) it insulates your plugin against changes in the structure members so that it does not have to be recompiled after such changes; 2) it is a little more object-oriented. The disadvantages are: 1) it is a little clumsier than operating directly on structure members, particularly when looping on contours and objects; and 2) you may find that there is no function to perform a needed operation on a structure member. In the latter case, we can easily add such functions, but then you will be constrained to running with the latest IMOD. It is recommended that you try to keep the structures private when you start work on a plugin, and only switch to accessing structure members if that turns out to be necessary.
Exported Functions and Include Files. In Linux and Mac OS X, all global functions in 3dmod are available to a plugin; whereas in Windows, only functions that are explicitly exported (using DLL_EX_IM) are available. For portability, it is recommended that you use only the exported functions. If you find that you need other functions, we can in most cases easily add the export macro and shift them from private to public header files. If you look at the plugin Makefile, you will see that it copies several headers from the imod directory instead of adding that directory to the include path. These are the headers needed for all the exported functions in 3dmod. All of the headers in IMOD/include are also available to a plugin since that directory is on the include path. All C library functions should be available to a plugin.
ImodView Structure. Many of the functions for interacting with 3dmod pass a pointer to an ImodView structure. This structure has all the information about the data loaded into 3dmod. In principle, there could be more than one such structure, allowing a multi-document type interface; but this capability has never been implemented, so there is just the one ImodView structure in the application. Nevertheless, we keep passing it around.
Dialog Manager and Drawing Control Functions. Every window, either dialog or graphical display, must register with a dialog manager. There is one dialog manager for 3dmod windows and one for model view windows. Plugins would register with imodDialogManager (since plugins to model view are not yet allowed). Follow the example of what beadfixer does to avoid crashes upon closing the window or exiting the program. Image drawing windows have the additional need to register themselves as drawing "controls" so that they get drawn at appropriate times. See the code for image drawing windows for examples of how this is done; locator.cpp would be the simplest.
Sharing You Plugin. If your plugin is generally useful, you may want other people to have access to it. First note the constraints imposed by using Qt. In general, to distribute software using Qt, you must either hold a Qt license or make the source available under an open source license (either GPL or the Q Public License, as far as we could tell). The Qt-related components of IMOD are open source under the GPL. With this in mind, there are at least three ways in which a plugin could be distributed:
Function to be defined by all plugins.  
Returns the name of the
plugin, which will be inserted in the Special menu and used to send
imodsendevent messages by name.  Bit flags made by OR'ing IMOD_PLUG_ values
for the type of plugin are returned in type.  
Not all of 3dmod's data structures may be initialized at the time
this function is called, so no initialization should be done.  However,
an image loading plugin can call iiAddCheckFunction at this time.
Menu execution function for plugins with the IMOD_PLUG_MENU bit set.  
vw is the pointer to the view structure, which should be stored and used
when calling back into the program.
imodPlugExecute will be called if available; if not defined then
the following call will be made: 
imodPlugExecuteType(inView, IMOD_PLUG_MENU, IMOD_REASON_EXECUTE);
Function for notification that 3dmod initialization is complete (with inType equal to 0 and inReason equal to IMOD_REASON_STARTUP), and for need to update for a change in model (with inType equal to 0 and inReason equal to IMOD_REASON_MODUPDATE). It is also an alternate function for opening through the menu.
Key input callback function to be defined by plugins with the
IMOD_PLUG_KEYS bit set.  
This function can be used to override 3dmod hot key settings; it is called
by image windows before they process a key event.
A nonzero return value indicates that the plugin handled the input key.
and that no other action should be taken by the 3dmod program.
A zero return value indicates that 3dmod should process the key as usual.
Mouse event callback function to be defined by plugins with the
IMOD_PLUG_MOUSE bit set.  
This function can be used to override 3dmod mouse actions in the Zap
window.  imx and imy will contain the image position, and but1,
but2, and but3 will indicate the state of the 3 buttons as mapped by
user preferences.  The return value should be the sum of two values:
  1 if the plugin handled the mouse event, indicating that no other action
should be taken with the event itself by the 3dmod program.
  2 if the specific calling window should draw itself, without issuing a
general program redraw.  If this is not sufficient, the plugin should call
ivwRedraw instead of setting this bit.
  A zero return value indicates that 3dmod should process the event as
usual.
This function is called only when a mouse button is down, unless mouse
tracking is enabled with ivwTrackMouseForPlugs.
General event callback function to be defined by plugins with the
IMOD_PLUG_EVENT bit set.  
This function can be used to receive notification of selected events from a
Zap window, currently QEvent::Enter, QEvent::Leave, and QEvent::Wheel (which
can be cast to QWheelEvent). imx and imy will contain the image position
of the mouse at the time of the event.  The return value should be the sum
of 1 and 2 as for imodPlugMouse, or 0 if the event should be processed as
usual.  It should not be necessary to process Enter and Leave events
since the Zap window uses them to manage the removal of a cursor-like extra
object created by a plugin.
Function to execute a message, to be defined by plugins with the
IMOD_PLUG_MESSAGE bit set.  
The entire message string is in the strings argument; arg is the index
of the current string and should be returned with the index of the last
string of the message executed by this plugin.
A non-zero return indicates an error.
Function to get a filename for a file to open.  This and the following file chooser
functions are called if defined by plugins with the
IMOD_PLUG_CHOOSER bit set.  When 3dmod calls for a file choosing operation,
the appropriate call is made to the first file chooser plugin that defines that
function.  If none exists, then the corresponding QFileDialog static chooser
function is called.  File chooser plugins will be accessed only if
the program is started in a way that brings up either the startup window or a
file chooser for an image file. 
imodPlugOpenFileName should behave like QFileDialog::getOpenFileName when called with
these four arguments.
Function to get multiple multiple filenames to open. It should behave like QFileDialog::getOpenFileName when called with these four arguments.
Function to get a filename for saving a file. It should behave like QFileDialog::getSaveFileName when called with these two arguments.
/* image data or color map has changed; windows need to clear caches and draw all images */ #define IMOD_DRAW_IMAGE (1) /* The current point x, y, z position has been changed. This causes an update of the info window x/y/z, image scale dialog if multifile Z loaded, the image processing window, and the isosurface window. Model view will be drawn if the image display is on, unless the IMOD_DRAW_SKIPMODV flag is also set. */ #define IMOD_DRAW_XYZ (1<<1) /* Model data or current model object/contour/point has been changed. Prior to XYZ update, this causes update to info window obj/cont/pt, and to object edit, cont/surf/pt, contour move and fine grain dialogs and update of plugins with IMOD_REASON_MODUPDATE. Model view will be drawn unless the IMOD_DRAW_SKIPMODV flag is also set. */ #define IMOD_DRAW_MOD (1<<2) /* A slicer location has changed; Zap and XYZ windows will draw slicer lines */ #define IMOD_DRAW_SLICE (1<<3) /* Skip drawing model view. Use this to cause a draw of image windows when a model view draw is already inevitable */ #define IMOD_DRAW_SKIPMODV (1<<5) /* Color index mode color map has changed. Do not combine with other flags. */ #define IMOD_DRAW_COLORMAP (1<<11) /* Do not resync image to model point. This keeps Zap from recentering. */ #define IMOD_DRAW_NOSYNC (1<<12) /* Recalculate cursor position: adds the IMOD_DRAW_MOD flag, and if there is a current model point defined, sets current point x,y,z to it and adds the IMOD_DRAW_XYZ flag */ #define IMOD_DRAW_RETHINK (1<<13) #define IMOD_DRAW_ACTIVE (1<<14) /* current window is active. */ #define IMOD_DRAW_TOP (1<<15) /* current window has highest priority. */ #define IMOD_DRAW_ALL (IMOD_DRAW_IMAGE | IMOD_DRAW_XYZ | IMOD_DRAW_MOD)
#define IMOD_PLUG_MENU 1 /* Add to special plugin menu. */ #define IMOD_PLUG_TOOL 2 /* Add to toolbar (not implemented) */ #define IMOD_PLUG_PROC 4 /* Add to image proc window. (not implemented) */ #define IMOD_PLUG_VIEW 8 /* Add to model view window. (not implemented) */ #define IMOD_PLUG_KEYS 16 /* Handle key events. */ #define IMOD_PLUG_FILE 32 /* Allow other image files to be loaded (?). */ #define IMOD_PLUG_MESSAGE 64 /* Execute messages */ #define IMOD_PLUG_MOUSE 128 /* Handle mouse events */ #define IMOD_PLUG_EVENT 256 /* Handle other events (wheel, enter, leave) */ #define IMOD_PLUG_CHOOSER 512 /* Handle file choosing operations */ #define IMOD_REASON_EXECUTE 1 /* Execute plugin after selection from menu */ #define IMOD_REASON_STARTUP 3 /* 3dmod has started. Initialize plugin. */ #define IMOD_REASON_MODUPDATE 4 /* Update the plugin for model changes */ #define IMOD_REASON_NEWMODEL 5 /* Update the plugin for new model loaded */
#define SnapShot_Default 0 #define SnapShot_RGB 1 #define SnapShot_TIF 2 #define SnapShot_PNG 3 #define SnapShot_JPG 4 /**************************** Application Data *******************************/ /* DOC_CODE Color defines */ /* color defines. */ #define COLOR_BACKGROUND 1 /* background color */ #define COLOR_FOREGROUND 2 /* foreground color */ #define COLOR_SELECT 3 /* selection color */ #define COLOR_SHADOW 4 /* shadowed selection color */ #define COLOR_END 5 /* endpoint color */ #define COLOR_BEGIN 6 /* begin point color */ #define COLOR_POINT 7 /* point color */ #define COLOR_GHOST 8 /* ghost color, darker version of object. */ #define COLOR_ARROW 9 /* first arrow color */ #define COLOR_ARROW2 10 /* second arrow color */ #define COLOR_ARROW3 11 /* third arrow color */ #define COLOR_ARROW4 12 /* fourth arrow color */ #define COLOR_MIN 13 /* The index of the minimum image value. */ #define COLOR_MAX 14 /* The index of the maximum image value. */
Draw model using a 2D line renderer implemented with OpenGL functions. This is the function used to draw the slicer window. You will need to set up the view matrix yourself, including Z limits in the projection to avoid getting the whole model drawn on a slice. Set drawCurrent nonzero to have current image or model point and current contour end symbols drawn too. Provide the z-scaling used to render the image in zscale.
Gets the color depth; 24 on current systems with no color index mode *
Returns the pixel value of the given COLOR_ value in inColor, used to call b3dColorIndex
Print text to the 3dmod information window. The usage of this function is similar to the usage of the stdio function printf.
Prints an error message with printf-type arguments This function will output a message box if out is NULL or under Windows; otherwise it will print to out, which should be stdout or stderr
Prints a message to standard error with printf-type arguments This function will flush stderr under Windows
Prints a message using imodPrintStderr if the letter key is entered as a debug key letter with -D
Puts message to standard error like puts, but flushes under Windows
Prints message to standard out, or to a message box under Windows
Passes even to the general key handler to execute 3dmod hot keys
Shows a help page with filename page in Qt Assistant; provide a full path if the path is not relative to IMOD_DIR/html/3dmodHelp. Returns 1 for error, 0 for success
Sends a message to all 3dmod image windows that a redraw is needed. inFlags should contain an OR of the various IMOD_DRAW_ flags.
The general draw update function. If a current model point is defined, calls for a draw with IMOD_DRAW_ALL; otherwise calls with IMOD_DRAW_MOD.
Gets the dimensions of the loaded image into outX, outY, outZ
Gets the current marker point location into outX, outY, outZ
Gets the current marker point location into outPoint
Sets the current marker point location as inX, inY, inZ
Sets the current marker point location from inPoint. Z and Y are truncated and Z is rounded to integers to be consistent with ivwSetLocation.
Returns the maximum time index, the current time is returned in outTime. When there is only a single image file, the maximum index and time index are both 0; when there are multiple times the index is numbered from 1.
Sets the current time to inTime
Gets the label for the current time.
Gets the label for time inIndex.
Sets the time for a new contour cont in object obj to match the current image time.
Gets the mode of the image data stored in the program. It will be 0 for bytes, MRC_MODE_USHORT (6) for unsigned shorts, or MRC_MODE_RGB (16) for RGB triplets.
Returns true if image data are loaded into a tile or strip cache. If this is the case, then the regular image access functions ivwGetZSection and ivwGetZSectionTime will return NULL, and either ivwGetCurrentZSection or ivwGetTileCachedSection must be used instead.
Returns line pointers to loaded image data for the given Z section, inSection. The line pointers are an array of pointers to the data on each line in Y. The return value must be cast to (b3dUInt16 **) to use to access array values when unsigned shorts are loaded. Returns NULL if data are loaded as strips or tiles.
Returns line pointers to loaded image data for the current Z section. If data are loaded as strips or tiles, this will load all tiles in the section if necessary/
Returns line pointers to loaded image data for the Z slice section and time index time. Returns NULL if data are loaded as strips or tiles.
Returns line pointers to a buffer with the entire Z slice section loaded from the highest resolution image file, when data are cached as tiles or strips. This call will force all of the data to be loaded synchronously, which can be time-consuming if images are large. The call will allocate an array for the image which should be freed when operations are done (or when a window closes) by calling ivwFreeTileCachedSection.
Frees the arrays allocated when ivwGetTileCachedSection is called, if they have been allocated; otherwise does nothing.
Returns a lookup table for mapping from unsigned short values to bytes based on the current setting of the Low and High range sliders. It calls get_short_map, which returns an allocated map that must be freed.
Copies one Z plane of a loaded image with line pointers in image as bytes to the buffer buf. If the loaded image is unsigned shorts, it is scaled based on the current settings of the Low and High range sliders. Returns 1 for failure to get a lookup table.
Returns true if there is an image loaded and it is not RGB
Returns grey scale value in memory for given image coordinate inX, inY, inZ. Works when loaded data are bytes or unsigned shorts, but not RGB.
Return value from image file.
Reads tilt angles, or any set of floating point values from the text file fname. The file should have one value per line. Returns 1 for error opening the file, or 2 for memory error.
Returns a pointer to angles read from a file, or NULL if there are none, and returns the number of angles in numAngles. If a subset in Z was read in, this function assumes the tilt angle list was for the complete stack and returns a pointer that starts at the starting Z.
Gets the model associated with the view.
Gets the number of a free extra object; returns a number greater than 1 or -1 for an error. A plugin could claim an object it opens and free it when it closes.
Clears out and releases the extra object specified by objNum. Returns 1 for an object number out of bounds.
Gets pointer to the extra object specified by objNum. Do not save this in a static structure; always get a new pointer before working with it. Returns NULL for an object number out of bounds.
Deletes all contours, meshes, and general storage data in the extra object specified by objNum.
Gets the original extra object. Do not use this. Get a free object number and use that instead.
Delete all contours in the original extra object
Gets the pixel size from the model if there are no units defined or if pixel size is constant; otherwise gets the size appropriate for the current image file and current section.
Enable or disable drawing of stippled contours
Enable or disable sending mouse moves with button up to plugins
Gets the current contour or makes a new one if there is none in object obj, at the current time or the time indicated by timeLock.
Returns 1 if in model mode or 0 if in movie mode
Sets the program into movie or model mode if mode is IMOD_MMOVIE or IMOD_MMODEL, or toggles the mode if mode is IMOD_MM_TOGGLE. This will cause a redraw.
Returns non-zero if contrast is reversed, otherwise returns 0
Return true if it is possible to display images in overlay mode in the Zap window.
Sets the overlay mode section difference to sec, reverse contrast if reverse is nonzero, and displays current or other section in green if whichGreen is 0 or 1.
Returns the Z slice of the top Zap window in outZ. The return value is 1 if there is no Zap window.
Sets the Z slice of the top Zap window to inZ. This will set the Zap window's section number if it is locked, or the current point location if not, but in either case it will not cause a redraw. The return value is 1 if there is no Zap window or inZ is out of range.
Returns the zoom of the top Zap window in outZoom. The return value is 1 if there is no Zap window.
Sets the zoom of the top Zap window to inZoom and redraws that Zap window if draw is true. Returns 1 if there is no Zap window or the zoom value is out of the range 0.005 to 200.
Returns the image coordinates of the mouse in the top Zap window in imagePt. The X and Y coordinates may be out of range if the mouse is outside the graphics area. The return value is 1 if there is no Zap window.
Returns the image coordinates at the center of the top Zap window in imX and imY, and its current Z coordinate in imZ. The return value is 1 if there is no top Zap window.
Sets the image coordinates at the center of the top Zap window to imX and imY, and its current Z coordinate to imZ. If draw is true, either draws the Zap window (if it is locked) or issues a general draw command; otherwise the caller is responsible for drawing. The return value is 1 if there is no top Zap window or if coordinates are out of range.
Returns the current device/pixel ratio for the top Zap window.
Returns the name of the current image file being displayed. If multiple single-image files are loaded in Z, returns the name of the file at the current Z slice. If asEntered is false, it returns a correct absolute path; otherwise, it returns the path as the user entered it, which may not be correct if the file is listed in an image descriptor file located in another directory.
Set the captions for the next single-frame snapshot of an image or model view window. captionLines can contain a series of captions. All but the last will be drawn on a single line. If wrapLastLine is true, the last string will be drawn on multiple lines with text wrapping at word boundaries.
Takes a single-frame snapshot of the top Zap window. If name is not empty, the snapshot will be given that filename; otherwise, the name is automatically generated as usual and returned in name. The snapshot format is specified by format, which should be SnapShot_TIF, SnapShot_PNG, or SnapShot_JPG, not the ambiguous SnapShot_RGB. For a TIFF snapshot, the user's choice of whether to convert to gray-scale is honored if checkGrayConvert is true and ignored otherwise. If fullArea is true, the snapshot will be of the whole window even if there is a rubber band. Returns -1 if there is no top zap window, -2 if the format is not one of the three listed, -3 if the format is not available as the first or second nonTiff format selected by the user, or 1 for any kind of error in the snapshotting process.
Takes a single-frame snapshot of the top Slicer window; arguments and return values are the same as in ivwSnapshotTopZap.
Starts a new arrow, retaining any existing arrows, in the top window of the type given by windowType, which can be either ZAP_WINDOW_TYPE or SLICER_WINDOW_TYPE. Returns -4 for an invalid type and -1 if there is no top window.
Clears all arrows in the top window of the type given by windowType if allWindows is false, or all windows of that type if allWindows is true. windowType can be either ZAP_WINDOW_TYPE or SLICER_WINDOW_TYPE. Returns -4 for an invalid type and -1 if there are now windows of the given type.
Returns the X, Y, and Z angles of the top slicer in angles, the center position in center, and the time of that slicer in time. The return value is 1 if there is no slicer open.
Returns the zoom of the top slicer window in outZoom. The return value is 1 if there is no slicer open.
Returns the thickness (number of slices summed) of the top slicer window in outZoom. The return value is 1 if there is no slicer open.
Returns the image coordinates of the mouse in the top Slicer window in imagePt. The X and Y coordinates may be out of range if the mouse is outside the graphics area. The return value is 1 if there is no Slicer window.
Returns the window type (e.g., ZAP_WINDOW_TYPE, etc) calling a plugin with a key, mouse or general event
Returns the lengths of the scale bars in the top windows of each of the different types, Zap, Slicer, XYZ, multiZ, or model view. A -1 is returned if there are no scale bars being displayed or if the particular window is not open. Call imodUnits with the current model to obtain a units string.
Enables or disables the drawing of scale bars without the Scale Bar dialog open.
Opens or raises the 3dmod dialog windows specified by the key letters provided in keys, where the letters are the same as can be given with the -E option.
Returns the current snapshot directory or an empty string if one is not set, in which case snapshots will be to QDir::currentPath().
Adds an item to the selection list defined by the object, contour, and point indices in newIndex.
Clears the selection list and returns the number previously on the list.
If contour co in object ob is on the selection list, returns the point number; otherwise returns -2. If co < 0, it simply tests whether the object is on the selection list and returns nonzero if so.
Removes contour co in object ob from the selection list if it is on it.
Manages the selection list when there is a new current point selected, for the model imod. The current point index is defined in indSave, and controlDown should be nonzero if the control key is down.
Returns the number of selected objects, and returns the minimum and maximum selected object number in minOb and maxOb.
Updates the Object Type dialog, the Model View Edit Object and Object List dialogs, and the color in the Info window.
Saves settings in the user preferences under a key given by key, which should be the name of a module. It saves numVals values from the array values. Returns 1 for memory allocation errors.
Returns settings from the user preferences under the key given by key. Up to maxVals values are returned into the array values. The return value is the number of values returned.
Gets the name of a single existing file with a file chooser that will show caption in its title bar. A set of numFilters filters can be given in filters; the first will be the default filter. Returns an empty string if the user cancels. Uses the file chooser plugin if one is defined.
Gets the name of a file in which to save with a file chooser that will show caption in its title bar. Uses the file chooser plugin if one is defined.
Creates a new image drawing control for a 3dmod view and returns a
nonzero integer that is used as the inCtrlId when calling other control
functions.  
  The inDrawFunction is called when the 3dmod draw function is called.
The integer in the third argument contains the draw flags.
  The inQuitFunction is called when a user quits 3dmod.
  The inKeyFunction is optional and if it is not NULL it is called with
key events that dialogs do not accept.
  data should be a pointer to the window's data structure so that
multiple instances can be distinguished
Deletes the control associated with the ID inCtrlId. This will also call the quit callback function of the control.
Removes the control associated with the ID inCtrlId. This does not call the quit callback function of the control and is typically called by the control itself when it is closing.
Moves the control with ID inCtrlId to the top of the control queue if it exists. Also sets this one as the active control, which means that it alone is drawn with the IMOD_DRAW_ACTIVE flag. If necessary, pending draws are stopped before the conrol queue is reordered. Returns the ID of the highest priority control.
Makes the control with ID inCtrlId the active one, which means that if it is also the top priority control, it is drawn with the IMOD_DRAW_ACTIVE flag. A zero value for inCtrlId make no control the active one.
Passes a key event e on to the first control on the list that has a key callback.
For a Mac version built with Qt 5, checks whether the Model View or Info Window menu is currently displayed and whether it should be displayed when a widget of the given dialogType is activated. To switch the menu if necessary, it activates the Model View or Info Window then activates the calling window again. This should be called from a changeEvent handler with the event, "this" for widget, and dialogType equal to IMOD_DIALOG for a standard plugin.
Returns true if the current style has rounded buttons on a Mac.
Definitions for controls.
typedef void (*ImodControlProc)(struct ViewInfo *, void *, int); typedef void (*ImodControlKey)(struct ViewInfo *, void *, int, QKeyEvent *);
class DialogManager;
/* Global instances */
extern DLL_EX_IM DialogManager imodvDialogManager;
extern DLL_EX_IM DialogManager imodDialogManager;
/* Classes of windows for the dialog manager */
#define IMODV_DIALOG 0
#define IMOD_DIALOG  1
#define IMOD_IMAGE   2
/* Types of windows for finding geometries and finding top windows */
enum {ZAP_WINDOW_TYPE, MULTIZ_WINDOW_TYPE, SLICER_WINDOW_TYPE, XYZ_WINDOW_TYPE,
      GRAPH_WINDOW_TYPE, TUMBLER_WINDOW_TYPE, DOCKING_DIALOG_TYPE, UNKNOWN_TYPE};
Methods in the DialogManager class.
Processes events, adjusts size of widget if doSize is true, makes sure it is fully on the desktop, then shows the widget. On Mac OSX, if dlgClass is non-negative, the widget is retored to the window manager's position then, if necessary, moved so as not to overlay the parent (Info window or model view).
Adds widget to the list for this DialogManager. The class of dialog or window is given in dlgClass and the specific type, if any, in dlgType (default UNKNOWN_TYPE), and a control ID can be supplied in ctrlId.
Removes widget from the list for this DialogManager.
On Mac OSX, returns the parent window for the give type of dialog/window, dlgClass. Elsewhere, returns NULL.
Register change of given type for contour in object, between point and point2. The default for object, contour and point are the current object, contour, or point if any is < -1; the default for point2 is point if point2 < 0.
Register change of given type for contour in object, potentially involving contour2 in object2. The default for object or contour are the current object or contour if one is < -1.
Register change of given type for [object, potentially involving object2. The default for object is the current object if it is < -1.
Register change in the model of given type. point specifies the shift for a PointShift
Register shift of current point
Register shift of point with index point in current contour
Register addition of point with index point in current contour
Register addition of points from index point to index point2 in current contour
Register addition of a point at index point in contour of object
Register deletion of the current point
Register deletion of the point at index point in the current contour
Register deletion of points from index point to point2 in the current contour.
Register change in the data (points) of the current contour
Register change in the data of contour in object
Register change in properties only of the current contour
Register change in properties only of contour in object
Register deletion of current contour
Register deletion of contour with index contour in current object
Register deletion of contour in object
Register addition of contour at index contour in current object
Register addition of contour at index contour in object
Register move of a contour from object, contour to object2, contour2.
Register a change in properties of the current object
Register a change in properties of object at index object
Register deletion of the current object
Register deletion of an object at index object
Register addition of an object at index object
Register moving an object from index object to object2
Register a shift of the model by amounts in point
Finish (close) a unit of changes to the model. Either this function or the flush function must always be called eventually after registering changes.
Flush all the changes that were registered since this unit of changes was started. Call this function if an operation is aborted due to an error after changes were registered.