fxruby 1.6.19-x86-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +456 -0
- data/README +39 -0
- data/doc/apes02.html +21 -0
- data/doc/apes03.html +39 -0
- data/doc/book.html +3 -0
- data/doc/build.html +132 -0
- data/doc/ch03s02.html +23 -0
- data/doc/ch03s03.html +52 -0
- data/doc/ch03s04.html +36 -0
- data/doc/ch03s05.html +60 -0
- data/doc/ch04s02.html +71 -0
- data/doc/ch04s03.html +37 -0
- data/doc/ch04s04.html +72 -0
- data/doc/ch05s02.html +260 -0
- data/doc/ch05s03.html +127 -0
- data/doc/changes.html +777 -0
- data/doc/clipboardtut.html +67 -0
- data/doc/differences.html +190 -0
- data/doc/dragdroptut.html +263 -0
- data/doc/events.html +36 -0
- data/doc/examples.html +104 -0
- data/doc/gems.html +73 -0
- data/doc/goals.html +41 -0
- data/doc/images/babelfish.png +0 -0
- data/doc/images/browser.png +0 -0
- data/doc/images/button.png +0 -0
- data/doc/images/call-chain-example.png +0 -0
- data/doc/images/colordialog.png +0 -0
- data/doc/images/datatarget.png +0 -0
- data/doc/images/dialog.png +0 -0
- data/doc/images/dilbert.png +0 -0
- data/doc/images/dirlist.png +0 -0
- data/doc/images/dropsite-droprejected.png +0 -0
- data/doc/images/foursplit.png +0 -0
- data/doc/images/gltest.png +0 -0
- data/doc/images/glviewer.png +0 -0
- data/doc/images/groupbox.png +0 -0
- data/doc/images/header.png +0 -0
- data/doc/images/hello-with-button.png +0 -0
- data/doc/images/hello-with-icon-1.png +0 -0
- data/doc/images/hello-with-icon-2.png +0 -0
- data/doc/images/hello-with-icon-3.png +0 -0
- data/doc/images/hello-with-tooltip.png +0 -0
- data/doc/images/hello-without-button.png +0 -0
- data/doc/images/hello.png +0 -0
- data/doc/images/hello2.png +0 -0
- data/doc/images/iconlist-bigicons.png +0 -0
- data/doc/images/iconlist-details.png +0 -0
- data/doc/images/image.png +0 -0
- data/doc/images/imageviewer.png +0 -0
- data/doc/images/inheritance.png +0 -0
- data/doc/images/mditest.png +0 -0
- data/doc/images/raabrowser.png +0 -0
- data/doc/images/scribble.png +0 -0
- data/doc/images/shutter.png +0 -0
- data/doc/images/splitter.png +0 -0
- data/doc/images/tabbook.png +0 -0
- data/doc/images/table.png +0 -0
- data/doc/images/tutorial1.png +0 -0
- data/doc/implementation.html +16 -0
- data/doc/infosources.html +33 -0
- data/doc/library.html +30 -0
- data/doc/opengl.html +73 -0
- data/doc/pt01.html +3 -0
- data/doc/pt02.html +3 -0
- data/doc/scintilla.html +36 -0
- data/doc/style.css +247 -0
- data/doc/subversion.html +21 -0
- data/doc/tutorial1.html +90 -0
- data/doc/unicode.html +56 -0
- data/examples/RAA.rb +25 -0
- data/examples/README +53 -0
- data/examples/babelfish.rb +72 -0
- data/examples/bounce.rb +159 -0
- data/examples/browser.rb +191 -0
- data/examples/button.rb +168 -0
- data/examples/charts.rb +35 -0
- data/examples/custom_table_item.rb +170 -0
- data/examples/datatarget.rb +223 -0
- data/examples/dctest.rb +696 -0
- data/examples/dialog.rb +143 -0
- data/examples/dilbert.rb +66 -0
- data/examples/dirlist.rb +63 -0
- data/examples/dragdrop.rb +97 -0
- data/examples/dragsource.rb +80 -0
- data/examples/dropsite.rb +59 -0
- data/examples/foursplit.rb +97 -0
- data/examples/gltest.rb +330 -0
- data/examples/glviewer.rb +576 -0
- data/examples/groupbox.rb +392 -0
- data/examples/header.rb +149 -0
- data/examples/hello.rb +12 -0
- data/examples/hello2.rb +51 -0
- data/examples/iRAA.rb +153 -0
- data/examples/iconlist.rb +92 -0
- data/examples/icons/AngryGuyInBunnySuit.ico +0 -0
- data/examples/icons/FatBot.ico +0 -0
- data/examples/icons/FlippedySwitch.ico +0 -0
- data/examples/icons/LeGoon.ico +0 -0
- data/examples/icons/Net.ico +0 -0
- data/examples/icons/RedMacOS.ico +0 -0
- data/examples/icons/SawBlade.ico +0 -0
- data/examples/icons/backview.png +0 -0
- data/examples/icons/big.png +0 -0
- data/examples/icons/bigfolder.png +0 -0
- data/examples/icons/bigpenguin.png +0 -0
- data/examples/icons/bottomview.png +0 -0
- data/examples/icons/camera.png +0 -0
- data/examples/icons/capbutt.png +0 -0
- data/examples/icons/capnotlast.png +0 -0
- data/examples/icons/capproj.png +0 -0
- data/examples/icons/capround.png +0 -0
- data/examples/icons/colorpal.png +0 -0
- data/examples/icons/copy.png +0 -0
- data/examples/icons/cut.png +0 -0
- data/examples/icons/delimit.png +0 -0
- data/examples/icons/dippy.png +0 -0
- data/examples/icons/double_dash.png +0 -0
- data/examples/icons/filenew.png +0 -0
- data/examples/icons/fileopen.png +0 -0
- data/examples/icons/filesave.png +0 -0
- data/examples/icons/filesaveas.png +0 -0
- data/examples/icons/fonts.png +0 -0
- data/examples/icons/fox.png +0 -0
- data/examples/icons/foxicon.png +0 -0
- data/examples/icons/frontview.png +0 -0
- data/examples/icons/gem_big.png +0 -0
- data/examples/icons/gem_small.png +0 -0
- data/examples/icons/hello2.png +0 -0
- data/examples/icons/help.png +0 -0
- data/examples/icons/indent.png +0 -0
- data/examples/icons/jbevel.png +0 -0
- data/examples/icons/jmiter.png +0 -0
- data/examples/icons/jround.png +0 -0
- data/examples/icons/kill.png +0 -0
- data/examples/icons/leftview.png +0 -0
- data/examples/icons/light.png +0 -0
- data/examples/icons/minidoc.png +0 -0
- data/examples/icons/minifolder.png +0 -0
- data/examples/icons/minifolderopen.png +0 -0
- data/examples/icons/newfolder.png +0 -0
- data/examples/icons/nolight.png +0 -0
- data/examples/icons/onoff_dash.png +0 -0
- data/examples/icons/palette.png +0 -0
- data/examples/icons/parallel.png +0 -0
- data/examples/icons/paste.png +0 -0
- data/examples/icons/pattern.png +0 -0
- data/examples/icons/penguin.png +0 -0
- data/examples/icons/perspective.png +0 -0
- data/examples/icons/printicon.png +0 -0
- data/examples/icons/prop.png +0 -0
- data/examples/icons/redo.png +0 -0
- data/examples/icons/rightview.png +0 -0
- data/examples/icons/saveas.png +0 -0
- data/examples/icons/shutter1.png +0 -0
- data/examples/icons/shutter2.png +0 -0
- data/examples/icons/small.png +0 -0
- data/examples/icons/smoothlight.png +0 -0
- data/examples/icons/solid_line.png +0 -0
- data/examples/icons/tbuplevel.png +0 -0
- data/examples/icons/topview.png +0 -0
- data/examples/icons/undo.png +0 -0
- data/examples/icons/winapp.png +0 -0
- data/examples/icons/zoom.png +0 -0
- data/examples/image.rb +279 -0
- data/examples/imageviewer.rb +509 -0
- data/examples/inputs.rb +83 -0
- data/examples/mditest.rb +180 -0
- data/examples/pig.rb +77 -0
- data/examples/raabrowser.rb +122 -0
- data/examples/ratio.rb +80 -0
- data/examples/rulerview.rb +27 -0
- data/examples/scintilla-test.rb +81 -0
- data/examples/scribble-orig.rb +186 -0
- data/examples/scribble.rb +162 -0
- data/examples/shutter.rb +158 -0
- data/examples/splitter.rb +211 -0
- data/examples/styledtext.rb +82 -0
- data/examples/tabbook.rb +165 -0
- data/examples/table.rb +182 -0
- data/examples/textedit/commands.rb +114 -0
- data/examples/textedit/helpwindow.rb +299 -0
- data/examples/textedit/prefdialog.rb +239 -0
- data/examples/textedit/textedit.rb +1763 -0
- data/examples/unicode.rb +36 -0
- data/ext/fox16/fox16.so +0 -0
- data/index.html +14 -0
- data/lib/fox16/accel_table.rb +70 -0
- data/lib/fox16/aliases.rb +5611 -0
- data/lib/fox16/calendar.rb +217 -0
- data/lib/fox16/chore.rb +105 -0
- data/lib/fox16/colors.rb +280 -0
- data/lib/fox16/core.rb +700 -0
- data/lib/fox16/dict.rb +35 -0
- data/lib/fox16/exceptions_for_fxerror.rb +17 -0
- data/lib/fox16/execute_nonmodal.rb +70 -0
- data/lib/fox16/glgroup.rb +166 -0
- data/lib/fox16/glshapes.rb +456 -0
- data/lib/fox16/input.rb +59 -0
- data/lib/fox16/irb.rb +178 -0
- data/lib/fox16/iterators.rb +420 -0
- data/lib/fox16/keys.rb +1374 -0
- data/lib/fox16/kwargs.rb +2740 -0
- data/lib/fox16/missingdep.rb +14 -0
- data/lib/fox16/pseudokeyboard.rb +40 -0
- data/lib/fox16/pseudomouse.rb +87 -0
- data/lib/fox16/responder.rb +70 -0
- data/lib/fox16/responder2.rb +132 -0
- data/lib/fox16/scintilla.rb +3641 -0
- data/lib/fox16/settings.rb +18 -0
- data/lib/fox16/signal.rb +71 -0
- data/lib/fox16/splashscreen.rb +82 -0
- data/lib/fox16/timeout.rb +136 -0
- data/lib/fox16/undolist.rb +455 -0
- data/lib/fox16/version.rb +9 -0
- data/rdoc-sources/FX4Splitter.rb +156 -0
- data/rdoc-sources/FX7Segment.rb +54 -0
- data/rdoc-sources/FXAccelTable.rb +84 -0
- data/rdoc-sources/FXApp.rb +545 -0
- data/rdoc-sources/FXArrowButton.rb +69 -0
- data/rdoc-sources/FXBMPIcon.rb +67 -0
- data/rdoc-sources/FXBMPImage.rb +30 -0
- data/rdoc-sources/FXBitmap.rb +115 -0
- data/rdoc-sources/FXBitmapFrame.rb +31 -0
- data/rdoc-sources/FXBitmapView.rb +44 -0
- data/rdoc-sources/FXButton.rb +59 -0
- data/rdoc-sources/FXCURCursor.rb +13 -0
- data/rdoc-sources/FXCanvas.rb +18 -0
- data/rdoc-sources/FXCheckButton.rb +58 -0
- data/rdoc-sources/FXChoiceBox.rb +49 -0
- data/rdoc-sources/FXColorBar.rb +48 -0
- data/rdoc-sources/FXColorDialog.rb +37 -0
- data/rdoc-sources/FXColorList.rb +55 -0
- data/rdoc-sources/FXColorRing.rb +49 -0
- data/rdoc-sources/FXColorSelector.rb +65 -0
- data/rdoc-sources/FXColorWell.rb +65 -0
- data/rdoc-sources/FXColorWheel.rb +57 -0
- data/rdoc-sources/FXComboBox.rb +214 -0
- data/rdoc-sources/FXComposite.rb +34 -0
- data/rdoc-sources/FXCursor.rb +67 -0
- data/rdoc-sources/FXDC.rb +720 -0
- data/rdoc-sources/FXDCPrint.rb +127 -0
- data/rdoc-sources/FXDCWindow.rb +33 -0
- data/rdoc-sources/FXDataTarget.rb +66 -0
- data/rdoc-sources/FXDebugTarget.rb +25 -0
- data/rdoc-sources/FXDelegator.rb +23 -0
- data/rdoc-sources/FXDial.rb +107 -0
- data/rdoc-sources/FXDialogBox.rb +32 -0
- data/rdoc-sources/FXDict.rb +79 -0
- data/rdoc-sources/FXDirBox.rb +55 -0
- data/rdoc-sources/FXDirDialog.rb +47 -0
- data/rdoc-sources/FXDirList.rb +149 -0
- data/rdoc-sources/FXDirSelector.rb +64 -0
- data/rdoc-sources/FXDockBar.rb +151 -0
- data/rdoc-sources/FXDockHandler.rb +26 -0
- data/rdoc-sources/FXDockSite.rb +104 -0
- data/rdoc-sources/FXDockTitle.rb +26 -0
- data/rdoc-sources/FXDocument.rb +29 -0
- data/rdoc-sources/FXDragCorner.rb +19 -0
- data/rdoc-sources/FXDrawable.rb +27 -0
- data/rdoc-sources/FXDriveBox.rb +46 -0
- data/rdoc-sources/FXExtentd.rb +85 -0
- data/rdoc-sources/FXExtentf.rb +85 -0
- data/rdoc-sources/FXFileDialog.rb +217 -0
- data/rdoc-sources/FXFileDict.rb +131 -0
- data/rdoc-sources/FXFileList.rb +208 -0
- data/rdoc-sources/FXFileSelector.rb +184 -0
- data/rdoc-sources/FXFileStream.rb +27 -0
- data/rdoc-sources/FXFoldingList.rb +504 -0
- data/rdoc-sources/FXFont.rb +361 -0
- data/rdoc-sources/FXFontDialog.rb +14 -0
- data/rdoc-sources/FXFontSelector.rb +37 -0
- data/rdoc-sources/FXFrame.rb +53 -0
- data/rdoc-sources/FXGIFCursor.rb +50 -0
- data/rdoc-sources/FXGIFIcon.rb +31 -0
- data/rdoc-sources/FXGIFImage.rb +29 -0
- data/rdoc-sources/FXGLCanvas.rb +45 -0
- data/rdoc-sources/FXGLContext.rb +40 -0
- data/rdoc-sources/FXGLObject.rb +75 -0
- data/rdoc-sources/FXGLShape.rb +69 -0
- data/rdoc-sources/FXGLViewer.rb +332 -0
- data/rdoc-sources/FXGLVisual.rb +94 -0
- data/rdoc-sources/FXGradientBar.rb +301 -0
- data/rdoc-sources/FXGroupBox.rb +36 -0
- data/rdoc-sources/FXHeader.rb +411 -0
- data/rdoc-sources/FXHorizontalFrame.rb +29 -0
- data/rdoc-sources/FXICOIcon.rb +65 -0
- data/rdoc-sources/FXICOImage.rb +31 -0
- data/rdoc-sources/FXIcon.rb +38 -0
- data/rdoc-sources/FXIconDict.rb +48 -0
- data/rdoc-sources/FXIconList.rb +450 -0
- data/rdoc-sources/FXIconSource.rb +100 -0
- data/rdoc-sources/FXId.rb +34 -0
- data/rdoc-sources/FXImage.rb +292 -0
- data/rdoc-sources/FXImageFrame.rb +36 -0
- data/rdoc-sources/FXImageView.rb +35 -0
- data/rdoc-sources/FXInputDialog.rb +80 -0
- data/rdoc-sources/FXJPGIcon.rb +70 -0
- data/rdoc-sources/FXJPGImage.rb +38 -0
- data/rdoc-sources/FXKnob.rb +76 -0
- data/rdoc-sources/FXLabel.rb +72 -0
- data/rdoc-sources/FXList.rb +443 -0
- data/rdoc-sources/FXListBox.rb +191 -0
- data/rdoc-sources/FXMDIButton.rb +67 -0
- data/rdoc-sources/FXMDIChild.rb +155 -0
- data/rdoc-sources/FXMDIClient.rb +65 -0
- data/rdoc-sources/FXMainWindow.rb +26 -0
- data/rdoc-sources/FXMatrix.rb +57 -0
- data/rdoc-sources/FXMemoryBuffer.rb +28 -0
- data/rdoc-sources/FXMemoryStream.rb +50 -0
- data/rdoc-sources/FXMenuBar.rb +23 -0
- data/rdoc-sources/FXMenuButton.rb +84 -0
- data/rdoc-sources/FXMenuCaption.rb +53 -0
- data/rdoc-sources/FXMenuCascade.rb +18 -0
- data/rdoc-sources/FXMenuCheck.rb +30 -0
- data/rdoc-sources/FXMenuCommand.rb +26 -0
- data/rdoc-sources/FXMenuPane.rb +13 -0
- data/rdoc-sources/FXMenuRadio.rb +33 -0
- data/rdoc-sources/FXMenuSeparator.rb +21 -0
- data/rdoc-sources/FXMenuTitle.rb +27 -0
- data/rdoc-sources/FXMessageBox.rb +73 -0
- data/rdoc-sources/FXObject.rb +28 -0
- data/rdoc-sources/FXOptionMenu.rb +83 -0
- data/rdoc-sources/FXPCXIcon.rb +63 -0
- data/rdoc-sources/FXPCXImage.rb +31 -0
- data/rdoc-sources/FXPNGIcon.rb +66 -0
- data/rdoc-sources/FXPNGImage.rb +34 -0
- data/rdoc-sources/FXPPMIcon.rb +36 -0
- data/rdoc-sources/FXPPMImage.rb +31 -0
- data/rdoc-sources/FXPacker.rb +63 -0
- data/rdoc-sources/FXPicker.rb +27 -0
- data/rdoc-sources/FXPopup.rb +53 -0
- data/rdoc-sources/FXPrintDialog.rb +36 -0
- data/rdoc-sources/FXProgressBar.rb +57 -0
- data/rdoc-sources/FXProgressDialog.rb +36 -0
- data/rdoc-sources/FXQuatd.rb +164 -0
- data/rdoc-sources/FXQuatf.rb +173 -0
- data/rdoc-sources/FXRGBIcon.rb +64 -0
- data/rdoc-sources/FXRGBImage.rb +31 -0
- data/rdoc-sources/FXRadioButton.rb +70 -0
- data/rdoc-sources/FXRanged.rb +100 -0
- data/rdoc-sources/FXRangef.rb +100 -0
- data/rdoc-sources/FXRealSlider.rb +101 -0
- data/rdoc-sources/FXRealSpinner.rb +140 -0
- data/rdoc-sources/FXRecentFiles.rb +77 -0
- data/rdoc-sources/FXRectangle.rb +149 -0
- data/rdoc-sources/FXRegion.rb +64 -0
- data/rdoc-sources/FXRegistry.rb +56 -0
- data/rdoc-sources/FXReplaceDialog.rb +56 -0
- data/rdoc-sources/FXRootWindow.rb +17 -0
- data/rdoc-sources/FXRuler.rb +130 -0
- data/rdoc-sources/FXRulerView.rb +225 -0
- data/rdoc-sources/FXScintilla.rb +121 -0
- data/rdoc-sources/FXScrollArea.rb +86 -0
- data/rdoc-sources/FXScrollBar.rb +107 -0
- data/rdoc-sources/FXScrollPane.rb +28 -0
- data/rdoc-sources/FXScrollWindow.rb +38 -0
- data/rdoc-sources/FXSearchDialog.rb +24 -0
- data/rdoc-sources/FXSeparator.rb +74 -0
- data/rdoc-sources/FXSettings.rb +248 -0
- data/rdoc-sources/FXShell.rb +8 -0
- data/rdoc-sources/FXShutter.rb +102 -0
- data/rdoc-sources/FXSize.rb +95 -0
- data/rdoc-sources/FXSlider.rb +98 -0
- data/rdoc-sources/FXSphered.rb +80 -0
- data/rdoc-sources/FXSpheref.rb +80 -0
- data/rdoc-sources/FXSpinner.rb +136 -0
- data/rdoc-sources/FXSplashWindow.rb +27 -0
- data/rdoc-sources/FXSplitter.rb +89 -0
- data/rdoc-sources/FXSpring.rb +61 -0
- data/rdoc-sources/FXStatusBar.rb +42 -0
- data/rdoc-sources/FXStatusLine.rb +60 -0
- data/rdoc-sources/FXStream.rb +142 -0
- data/rdoc-sources/FXStringDict.rb +38 -0
- data/rdoc-sources/FXSwitcher.rb +78 -0
- data/rdoc-sources/FXTGAIcon.rb +63 -0
- data/rdoc-sources/FXTGAImage.rb +31 -0
- data/rdoc-sources/FXTIFIcon.rb +70 -0
- data/rdoc-sources/FXTIFImage.rb +37 -0
- data/rdoc-sources/FXTabBar.rb +80 -0
- data/rdoc-sources/FXTabBook.rb +41 -0
- data/rdoc-sources/FXTabItem.rb +58 -0
- data/rdoc-sources/FXTable.rb +975 -0
- data/rdoc-sources/FXText.rb +581 -0
- data/rdoc-sources/FXTextField.rb +151 -0
- data/rdoc-sources/FXToggleButton.rb +70 -0
- data/rdoc-sources/FXToolBar.rb +61 -0
- data/rdoc-sources/FXToolBarGrip.rb +50 -0
- data/rdoc-sources/FXToolBarShell.rb +44 -0
- data/rdoc-sources/FXToolBarTab.rb +74 -0
- data/rdoc-sources/FXToolTip.rb +39 -0
- data/rdoc-sources/FXTopWindow.rb +163 -0
- data/rdoc-sources/FXTranslator.rb +32 -0
- data/rdoc-sources/FXTreeList.rb +514 -0
- data/rdoc-sources/FXTreeListBox.rb +219 -0
- data/rdoc-sources/FXTriStateButton.rb +49 -0
- data/rdoc-sources/FXVec2d.rb +96 -0
- data/rdoc-sources/FXVec2f.rb +96 -0
- data/rdoc-sources/FXVec3d.rb +118 -0
- data/rdoc-sources/FXVec3f.rb +118 -0
- data/rdoc-sources/FXVec4d.rb +139 -0
- data/rdoc-sources/FXVec4f.rb +139 -0
- data/rdoc-sources/FXVerticalFrame.rb +29 -0
- data/rdoc-sources/FXVisual.rb +79 -0
- data/rdoc-sources/FXWindow.rb +725 -0
- data/rdoc-sources/FXWizard.rb +59 -0
- data/rdoc-sources/FXXBMIcon.rb +37 -0
- data/rdoc-sources/FXXBMImage.rb +32 -0
- data/rdoc-sources/FXXPMIcon.rb +65 -0
- data/rdoc-sources/FXXPMImage.rb +31 -0
- data/rdoc-sources/README.rdoc +53 -0
- data/rdoc-sources/fxdefs.rb +90 -0
- data/tests/README +19 -0
- data/tests/TC_FXAccelTable.rb +57 -0
- data/tests/TC_FXApp.rb +16 -0
- data/tests/TC_FXArc.rb +26 -0
- data/tests/TC_FXBMPIcon.rb +15 -0
- data/tests/TC_FXBMPImage.rb +15 -0
- data/tests/TC_FXButton.rb +78 -0
- data/tests/TC_FXCheckButton.rb +57 -0
- data/tests/TC_FXComboBox.rb +63 -0
- data/tests/TC_FXDC.rb +372 -0
- data/tests/TC_FXDCPrint.rb +101 -0
- data/tests/TC_FXDCWindow.rb +23 -0
- data/tests/TC_FXDataTarget.rb +24 -0
- data/tests/TC_FXDialogBox.rb +12 -0
- data/tests/TC_FXDirList.rb +30 -0
- data/tests/TC_FXExtentd.rb +21 -0
- data/tests/TC_FXExtentf.rb +21 -0
- data/tests/TC_FXFileAssoc.rb +62 -0
- data/tests/TC_FXFileStream.rb +89 -0
- data/tests/TC_FXFoldingList.rb +32 -0
- data/tests/TC_FXFont.rb +69 -0
- data/tests/TC_FXFontDesc.rb +58 -0
- data/tests/TC_FXGLGroup.rb +32 -0
- data/tests/TC_FXGLShape.rb +28 -0
- data/tests/TC_FXGLViewer.rb +20 -0
- data/tests/TC_FXGradientBar.rb +89 -0
- data/tests/TC_FXHeader.rb +82 -0
- data/tests/TC_FXHiliteStyle.rb +23 -0
- data/tests/TC_FXIconDict.rb +52 -0
- data/tests/TC_FXIconList.rb +192 -0
- data/tests/TC_FXId.rb +19 -0
- data/tests/TC_FXImage.rb +155 -0
- data/tests/TC_FXLight.rb +33 -0
- data/tests/TC_FXList.rb +116 -0
- data/tests/TC_FXListBox.rb +49 -0
- data/tests/TC_FXMainWindow.rb +19 -0
- data/tests/TC_FXMat4f.rb +228 -0
- data/tests/TC_FXMaterial.rb +89 -0
- data/tests/TC_FXMemoryStream.rb +97 -0
- data/tests/TC_FXMenuCheck.rb +57 -0
- data/tests/TC_FXMenuCommand.rb +12 -0
- data/tests/TC_FXMenuRadio.rb +57 -0
- data/tests/TC_FXMessageBox.rb +25 -0
- data/tests/TC_FXPoint.rb +57 -0
- data/tests/TC_FXQuatf.rb +93 -0
- data/tests/TC_FXRadioButton.rb +57 -0
- data/tests/TC_FXRanged.rb +42 -0
- data/tests/TC_FXRangef.rb +42 -0
- data/tests/TC_FXRectangle.rb +88 -0
- data/tests/TC_FXRegion.rb +54 -0
- data/tests/TC_FXRegistry.rb +27 -0
- data/tests/TC_FXScrollArea.rb +28 -0
- data/tests/TC_FXScrollWindow.rb +28 -0
- data/tests/TC_FXSegment.rb +22 -0
- data/tests/TC_FXSettings.rb +34 -0
- data/tests/TC_FXShell.rb +26 -0
- data/tests/TC_FXSize.rb +54 -0
- data/tests/TC_FXStream.rb +11 -0
- data/tests/TC_FXTable.rb +561 -0
- data/tests/TC_FXTableItem.rb +48 -0
- data/tests/TC_FXText.rb +96 -0
- data/tests/TC_FXTopWindow.rb +32 -0
- data/tests/TC_FXTreeList.rb +100 -0
- data/tests/TC_FXTreeListBox.rb +41 -0
- data/tests/TC_FXUndoList.rb +43 -0
- data/tests/TC_FXVec2d.rb +142 -0
- data/tests/TC_FXVec2f.rb +137 -0
- data/tests/TC_FXVec3d.rb +150 -0
- data/tests/TC_FXVec3f.rb +150 -0
- data/tests/TC_FXVec4f.rb +158 -0
- data/tests/TC_FXViewport.rb +30 -0
- data/tests/TC_FXXBMIcon.rb +15 -0
- data/tests/TC_FXXBMImage.rb +15 -0
- data/tests/TC_FXXPMIcon.rb +15 -0
- data/tests/TC_FXXPMImage.rb +15 -0
- data/tests/TC_Misc.rb +157 -0
- data/tests/TC_downcast.rb +15 -0
- data/tests/TS_All.rb +25 -0
- data/tests/blankpage.ps +166 -0
- data/tests/howdypage.ps +181 -0
- data/tests/stress1.rb +92 -0
- data/tests/stress2.rb +51 -0
- data/tests/stress3.rb +117 -0
- data/tests/testcase.rb +37 -0
- metadata +556 -0
@@ -0,0 +1,35 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# The FXImageView widget displays a scrollable view of an image.
|
4
|
+
#
|
5
|
+
# === Image alignment styles
|
6
|
+
#
|
7
|
+
# +IMAGEVIEW_NORMAL+:: Normal mode is centered
|
8
|
+
# +IMAGEVIEW_CENTER_X+:: Centered horizontally
|
9
|
+
# +IMAGEVIEW_LEFT+:: Left-aligned
|
10
|
+
# +IMAGEVIEW_RIGHT+:: Right-aligned
|
11
|
+
# +IMAGEVIEW_CENTER_Y+:: Centered vertically
|
12
|
+
# +IMAGEVIEW_TOP+:: Top-aligned
|
13
|
+
# +IMAGEVIEW_BOTTOM+:: Bottom-aligned
|
14
|
+
#
|
15
|
+
# === Events
|
16
|
+
#
|
17
|
+
# +SEL_RIGHTBUTTONPRESS+:: sent when the right mouse button goes down; the message data is an FXEvent instance.
|
18
|
+
# +SEL_RIGHTBUTTONRELEASE+:: sent when the right mouse button goes up; the message data is an FXEvent instance.
|
19
|
+
#
|
20
|
+
class FXImageView < FXScrollArea
|
21
|
+
|
22
|
+
# The image [FXImage]
|
23
|
+
attr_accessor :image
|
24
|
+
|
25
|
+
# Current alignment [Integer]
|
26
|
+
attr_accessor :alignment
|
27
|
+
|
28
|
+
#
|
29
|
+
# Return an initialized FXImageView instance.
|
30
|
+
#
|
31
|
+
def initialize(p, img=nil, target=nil, selector=0, opts=0, x=0, y=0, width=0, height=0) # :yields: theImageView
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
@@ -0,0 +1,80 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# An FXInputDialog is a simple dialog which is used
|
4
|
+
# to obtain a text string, integer, or real number from the user.
|
5
|
+
# A "password" mode allows the key-in to remain hidden.
|
6
|
+
#
|
7
|
+
# === Input dialog options
|
8
|
+
#
|
9
|
+
# +INPUTDIALOG_STRING+:: Ask for a string
|
10
|
+
# +INPUTDIALOG_INTEGER+:: Ask for an integer number
|
11
|
+
# +INPUTDIALOG_REAL+:: Ask for a real number
|
12
|
+
# +INPUTDIALOG_PASSWORD+:: Do not reveal key-in
|
13
|
+
#
|
14
|
+
class FXInputDialog < FXDialogBox
|
15
|
+
|
16
|
+
# Input string [String]
|
17
|
+
attr_accessor :text
|
18
|
+
|
19
|
+
# Number of visible columns of text [Integer]
|
20
|
+
attr_accessor :numColumns
|
21
|
+
|
22
|
+
#
|
23
|
+
# Construct input dialog box with given caption, icon, and prompt text.
|
24
|
+
# If _owner_ is a window, the dialog box will float over that window.
|
25
|
+
# If _owner_ is the application, the dialog box will be free-floating.
|
26
|
+
#
|
27
|
+
def initialize(owner, caption, label, icon=nil, opts=INPUTDIALOG_STRING, x=0, y=0, width=0, height=0) # :yields: theInputDialog
|
28
|
+
end
|
29
|
+
|
30
|
+
# Return the input dialog's input string text
|
31
|
+
def to_s; text; end
|
32
|
+
|
33
|
+
#
|
34
|
+
# Change limits (where _lo_ and _hi_ are numbers).
|
35
|
+
#
|
36
|
+
def setLimits(lo, hi); end
|
37
|
+
|
38
|
+
#
|
39
|
+
# Return limits (a two-element array of floats).
|
40
|
+
#
|
41
|
+
def getLimits(); end
|
42
|
+
|
43
|
+
#
|
44
|
+
# Prompt the user for a string, with the text field initialized
|
45
|
+
# to the specified _initial_ value. Return the input value if the
|
46
|
+
# user clicks *OK*, else return +nil+.
|
47
|
+
#
|
48
|
+
def FXInputDialog.getString(initial, owner, caption, label, ic=nil); end
|
49
|
+
|
50
|
+
#
|
51
|
+
# Prompt for a string, in a free-floating window..
|
52
|
+
#
|
53
|
+
def FXInputDialog.getString(initial, app, caption, label, ic=nil); end
|
54
|
+
|
55
|
+
#
|
56
|
+
# Prompt the user for an integer number, starting from the specified _initial_ value.
|
57
|
+
# Return the input value if the user clicks *OK*, else return +nil+.
|
58
|
+
# The input is constrained between _lo_ and _hi_.
|
59
|
+
#
|
60
|
+
def FXInputDialog.getInteger(initial, owner, caption, label, ic=nil, lo=-2147483647, hi=2147483647); end
|
61
|
+
|
62
|
+
#
|
63
|
+
# Prompt for an integer, in a free-floating window..
|
64
|
+
#
|
65
|
+
def FXInputDialog.getInteger(initial, app, caption, label, ic=nil, lo=-2147483647, hi=2147483647); end
|
66
|
+
|
67
|
+
#
|
68
|
+
# Prompt the user for a real number, starting from the specified _initial_ value.
|
69
|
+
# Return the input value if the user clicks *OK*, else return +nil+.
|
70
|
+
# The input is constrained between _lo_ and _hi_.
|
71
|
+
#
|
72
|
+
def FXInputDialog.getReal(initial, owner, caption, label, ic=nil, lo=-1.797693134862315e+308, hi=1.797693134862315e+308); end
|
73
|
+
|
74
|
+
#
|
75
|
+
# Prompt for a real number, in a free-floating window..
|
76
|
+
#
|
77
|
+
def FXInputDialog.getReal(initial, owner, caption, label, ic=nil, lo=-1.797693134862315e+308, hi=1.797693134862315e+308); end
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
@@ -0,0 +1,70 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# JPEG icon class
|
4
|
+
#
|
5
|
+
class FXJPGIcon < FXIcon
|
6
|
+
|
7
|
+
#
|
8
|
+
# Return the suggested file extension for this image type ("jpg").
|
9
|
+
#
|
10
|
+
def FXJPGIcon.fileExt; end
|
11
|
+
|
12
|
+
#
|
13
|
+
# Return the MIME type for this image type
|
14
|
+
#
|
15
|
+
def FXJPGIcon.mimeType; end
|
16
|
+
|
17
|
+
# Return +true+ if JPEG image file format is supported.
|
18
|
+
def FXJPGIcon.supported? ; end
|
19
|
+
|
20
|
+
# Image quality setting [Integer]
|
21
|
+
attr_accessor :quality
|
22
|
+
|
23
|
+
#
|
24
|
+
# Return an initialized FXJPGIcon instance.
|
25
|
+
#
|
26
|
+
# ==== Parameters:
|
27
|
+
#
|
28
|
+
# +a+:: an application instance [FXApp]
|
29
|
+
# +pix+:: a memory buffer formatted in JPEG file format [String]
|
30
|
+
# +clr+:: transparency color [FXColor]
|
31
|
+
# +opts+:: options [Integer]
|
32
|
+
# +width+:: width [Integer]
|
33
|
+
# +height+:: height [Integer]
|
34
|
+
#
|
35
|
+
def initialize(a, pix=nil, clr=0, opts=0, width=1, height=1) # :yields: theJPGIcon
|
36
|
+
end
|
37
|
+
end
|
38
|
+
#
|
39
|
+
# Load a JPEG file from a stream.
|
40
|
+
# If successful, returns an array containing the image pixel data (as a
|
41
|
+
# String), transparency color, image width, image height and quality.
|
42
|
+
# If it fails, the function returns +nil+.
|
43
|
+
#
|
44
|
+
# ==== Parameters:
|
45
|
+
#
|
46
|
+
# +store+:: stream from which to read the file data [FXStream]
|
47
|
+
#
|
48
|
+
def Fox.fxloadJPG(store); end
|
49
|
+
|
50
|
+
#
|
51
|
+
# Save a JPEG image to a stream.
|
52
|
+
# Returns +true+ on success, +false+ on failure.
|
53
|
+
#
|
54
|
+
# ==== Parameters:
|
55
|
+
#
|
56
|
+
# +store+:: stream to which to write the image data [FXStream]
|
57
|
+
# +data+:: the image pixel data [String]
|
58
|
+
# +transp+:: transparency color [FXColor]
|
59
|
+
# +width+:: width [Integer]
|
60
|
+
# +height+:: height [Integer]
|
61
|
+
# +quality+:: image quality [Integer]
|
62
|
+
#
|
63
|
+
def Fox.fxsaveJPG(store, data, transp, width, height, quality); end
|
64
|
+
|
65
|
+
#
|
66
|
+
# Return +true+ if _store_ (an FXStream instance) contains a JPEG image.
|
67
|
+
#
|
68
|
+
def Fox.fxcheckJPG(store); end
|
69
|
+
end
|
70
|
+
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# JPEG Image class
|
4
|
+
#
|
5
|
+
class FXJPGImage < FXImage
|
6
|
+
|
7
|
+
#
|
8
|
+
# Return the suggested file extension for this image type ("jpg").
|
9
|
+
#
|
10
|
+
def FXJPGImage.fileExt; end
|
11
|
+
|
12
|
+
#
|
13
|
+
# Return the MIME type for this image type
|
14
|
+
#
|
15
|
+
def FXJPGImage.mimeType; end
|
16
|
+
|
17
|
+
# Return +true+ if JPEG image file format is supported.
|
18
|
+
def FXJPGImage.supported? ; end
|
19
|
+
|
20
|
+
# Image quality
|
21
|
+
attr_accessor :quality
|
22
|
+
|
23
|
+
#
|
24
|
+
# Return an initialized FXJPGImage instance.
|
25
|
+
#
|
26
|
+
# ==== Parameters:
|
27
|
+
#
|
28
|
+
# +a+:: an application instance [FXApp]
|
29
|
+
# +pix+:: a memory buffer formatted in JPEG file format [String]
|
30
|
+
# +opts+:: options [Integer]
|
31
|
+
# +width+:: width [Integer]
|
32
|
+
# +height+:: height [Integer]
|
33
|
+
#
|
34
|
+
def initialize(a, pix=nil, opts=0, width=1, height=1) # :yields: theJPGImage
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
@@ -0,0 +1,76 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# The knob widget is a valuator widget which provides simple linear value range.
|
4
|
+
# While being moved, the knob sends +SEL_CHANGED+ messages to its target;
|
5
|
+
# at the end of the interaction, a final +SEL_COMMAND+ message is sent.
|
6
|
+
# The message data represents the current knob value (an integer).
|
7
|
+
#
|
8
|
+
# === Events
|
9
|
+
#
|
10
|
+
# The following messages are sent by FXKnob to its target:
|
11
|
+
#
|
12
|
+
# +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
|
13
|
+
# +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
|
14
|
+
# +SEL_LEFTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
|
15
|
+
# +SEL_LEFTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
|
16
|
+
# +SEL_MIDDLEBUTTONPRESS+:: sent when the middle mouse button goes down; the message data is an FXEvent instance.
|
17
|
+
# +SEL_MIDDLEBUTTONRELEASE+:: sent when the middle mouse button goes up; the message data is an FXEvent instance.
|
18
|
+
# +SEL_COMMAND+::
|
19
|
+
# sent at the end of a knob move; the message data is the new value of the knob.
|
20
|
+
# +SEL_CHANGED+::
|
21
|
+
# sent continuously while the knob is being moved; the message data is an integer indicating
|
22
|
+
# the current knob value.
|
23
|
+
#
|
24
|
+
# === Knob Control styles
|
25
|
+
#
|
26
|
+
# +KNOB_NEEDLE+:: Use a needle as indicator
|
27
|
+
# +KNOB_DOT+:: Use a dot as indicator
|
28
|
+
# +KNOB_TICKS+:: Show ticks around the knob
|
29
|
+
# +KNOB_INDICATOR+:: Show only the indicator (like a speedometer)
|
30
|
+
# +KNOB_NORMAL+:: Normal knob looks
|
31
|
+
#
|
32
|
+
class FXKnob < FXFrame
|
33
|
+
|
34
|
+
# Knob value [Integer]
|
35
|
+
attr_accessor :value
|
36
|
+
|
37
|
+
# Knob range [Range]
|
38
|
+
attr_accessor :range
|
39
|
+
|
40
|
+
# Knob style [Integer]
|
41
|
+
attr_accessor :knobStyle
|
42
|
+
|
43
|
+
# Knob auto-increment/decrement value [Integer]
|
44
|
+
attr_accessor :increment
|
45
|
+
|
46
|
+
# Delta between ticks [Integer]
|
47
|
+
attr_accessor :tickDelta
|
48
|
+
|
49
|
+
# Indicator needle color [FXColor]
|
50
|
+
attr_accessor :lineColor
|
51
|
+
|
52
|
+
# Help text displayed on the status line [String]
|
53
|
+
attr_accessor :helpText
|
54
|
+
|
55
|
+
# Tooltip text value [String]
|
56
|
+
attr_accessor :tipText
|
57
|
+
|
58
|
+
#
|
59
|
+
# Return a new FXKnob instance.
|
60
|
+
#
|
61
|
+
def initialize(p, target=nil, selector=0, opts=KNOB_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_PAD, padRight=DEFAULT_PAD, padTop=DEFAULT_PAD, padBottom=DEFAULT_PAD) # :yields: theKnob
|
62
|
+
end
|
63
|
+
|
64
|
+
#
|
65
|
+
# Change the knob's movement limits (start and ending angles)
|
66
|
+
# Accept values in degrees from 0 (south) to 360.
|
67
|
+
#
|
68
|
+
def setLimits(start_angle, end_angle, notify=false); end
|
69
|
+
|
70
|
+
#
|
71
|
+
# Return the knob's current limits as a two-element array.
|
72
|
+
#
|
73
|
+
def getLimits(); end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
@@ -0,0 +1,72 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# A label widget can be used to place a text and/or icon for
|
4
|
+
# explanation purposes. The text label may have an optional tooltip
|
5
|
+
# and/or help string. Icon and label are placed relative to the widget
|
6
|
+
# using the justfication options, and relative to each other as determined
|
7
|
+
# by the icon relationship options. A large number of arrangements is
|
8
|
+
# possible.
|
9
|
+
#
|
10
|
+
# === Justification modes
|
11
|
+
#
|
12
|
+
# +JUSTIFY_NORMAL+:: Default justification is centered text
|
13
|
+
# +JUSTIFY_CENTER_X+:: Text is centered horizontally
|
14
|
+
# +JUSTIFY_LEFT+:: Text is left-justified
|
15
|
+
# +JUSTIFY_RIGHT+:: Text is right-justified
|
16
|
+
# +JUSTIFY_HZ_APART+:: Combination of +JUSTIFY_LEFT+ & +JUSTIFY_RIGHT+
|
17
|
+
# +JUSTIFY_CENTER_Y+:: Text is centered vertically
|
18
|
+
# +JUSTIFY_TOP+:: Text is aligned with label top
|
19
|
+
# +JUSTIFY_BOTTOM+:: Text is aligned with label bottom
|
20
|
+
# +JUSTIFY_VT_APART+:: Combination of +JUSTIFY_TOP+ & +JUSTIFY_BOTTOM+
|
21
|
+
#
|
22
|
+
# === Relationship options for icon-labels
|
23
|
+
#
|
24
|
+
# +ICON_UNDER_TEXT+:: Icon appears under text
|
25
|
+
# +ICON_AFTER_TEXT+:: Icon appears after text (to its right)
|
26
|
+
# +ICON_BEFORE_TEXT+:: Icon appears before text (to its left)
|
27
|
+
# +ICON_ABOVE_TEXT+:: Icon appears above text
|
28
|
+
# +ICON_BELOW_TEXT+:: Icon appears below text
|
29
|
+
# +TEXT_OVER_ICON+:: Same as +ICON_UNDER_TEXT+
|
30
|
+
# +TEXT_AFTER_ICON+:: Same as +ICON_BEFORE_TEXT+
|
31
|
+
# +TEXT_BEFORE_ICON+:: Same as +ICON_AFTER_TEXT+
|
32
|
+
# +TEXT_ABOVE_ICON+:: Same as +ICON_BELOW_TEXT+
|
33
|
+
# +TEXT_BELOW_ICON+:: Same as +ICON_ABOVE_TEXT+
|
34
|
+
#
|
35
|
+
# === Normal way to show label
|
36
|
+
#
|
37
|
+
# +LABEL_NORMAL+:: Same as <tt>JUSTIFY_NORMAL|ICON_BEFORE_TEXT</tt>
|
38
|
+
#
|
39
|
+
class FXLabel < FXFrame
|
40
|
+
|
41
|
+
# The text for this label [String]
|
42
|
+
attr_accessor :text
|
43
|
+
|
44
|
+
# The icon for this label [FXIcon]
|
45
|
+
attr_accessor :icon
|
46
|
+
|
47
|
+
# The text font [FXFont]
|
48
|
+
attr_accessor :font
|
49
|
+
|
50
|
+
# The text color [FXColor]
|
51
|
+
attr_accessor :textColor
|
52
|
+
|
53
|
+
# Text justification mode [Integer]
|
54
|
+
attr_accessor :justify
|
55
|
+
|
56
|
+
# Icon position [Integer]
|
57
|
+
attr_accessor :iconPosition
|
58
|
+
|
59
|
+
# Status line help text [String]
|
60
|
+
attr_accessor :helpText
|
61
|
+
|
62
|
+
# Tool tip message [String]
|
63
|
+
attr_accessor :tipText
|
64
|
+
|
65
|
+
# Construct label with given text and icon
|
66
|
+
def initialize(parent, text, icon=nil, opts=LABEL_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_PAD, padRight=DEFAULT_PAD, padTop=DEFAULT_PAD, padBottom=DEFAULT_PAD) # :yields: theLabel
|
67
|
+
end
|
68
|
+
|
69
|
+
# Return the label's text
|
70
|
+
def to_s; text; end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,443 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# List item
|
4
|
+
#
|
5
|
+
class FXListItem < FXObject
|
6
|
+
|
7
|
+
# Text for this item [String]
|
8
|
+
attr_accessor :text
|
9
|
+
|
10
|
+
# Icon for this item [FXIcon]
|
11
|
+
attr_accessor :icon
|
12
|
+
|
13
|
+
# User data for this item [Object]
|
14
|
+
attr_accessor :data
|
15
|
+
|
16
|
+
# Indicates whether this item has the focus [Boolean]
|
17
|
+
attr_writer :focus
|
18
|
+
|
19
|
+
# Indicates whether this item is selected [Boolean]
|
20
|
+
attr_writer :selected
|
21
|
+
|
22
|
+
# Indicates whether this item is enabled [Boolean]
|
23
|
+
attr_writer :enabled
|
24
|
+
|
25
|
+
# Indicates whether this item is draggable [Boolean]
|
26
|
+
attr_writer :draggable
|
27
|
+
|
28
|
+
# Initialize
|
29
|
+
def initialize(text, icon=nil, data=nil) # :yields: theListItem
|
30
|
+
end
|
31
|
+
|
32
|
+
# Return the list item's text
|
33
|
+
def to_s; text; end
|
34
|
+
|
35
|
+
# Returns +true+ if this item has the focus
|
36
|
+
def hasFocus?() ; end
|
37
|
+
|
38
|
+
# Return +true+ if this item is selected
|
39
|
+
def selected?() ; end
|
40
|
+
|
41
|
+
# Return +true+ if this item is enabled
|
42
|
+
def enabled?() ; end
|
43
|
+
|
44
|
+
# Return +true+ if this item is draggable
|
45
|
+
def draggable?() ; end
|
46
|
+
|
47
|
+
# Return the width of this item for a specified list
|
48
|
+
def getWidth(list) ; end
|
49
|
+
|
50
|
+
# Return the height of this item for a specified list
|
51
|
+
def getHeight(list) ; end
|
52
|
+
|
53
|
+
# Create the item
|
54
|
+
def create() ; end
|
55
|
+
|
56
|
+
# Detach the item
|
57
|
+
def detach() ; end
|
58
|
+
|
59
|
+
# Destroy the item
|
60
|
+
def destroy( ); end
|
61
|
+
end
|
62
|
+
|
63
|
+
#
|
64
|
+
# A List Widget displays a list of items, each with a text and
|
65
|
+
# optional icon. When an item's selected state changes, the list sends
|
66
|
+
# a +SEL_SELECTED+ or +SEL_DESELECTED+ message. A change of the current
|
67
|
+
# item is signified by the +SEL_CHANGED+ message.
|
68
|
+
# The list sends +SEL_COMMAND+ messages when the user clicks on an item,
|
69
|
+
# and +SEL_CLICKED+, +SEL_DOUBLECLICKED+, and +SEL_TRIPLECLICKED+ when the user
|
70
|
+
# clicks once, twice, or thrice, respectively.
|
71
|
+
# When items are added, replaced, or removed, the list sends messages of
|
72
|
+
# the type +SEL_INSERTED+, +SEL_REPLACED+, or +SEL_DELETED+.
|
73
|
+
# In each of these cases, the index to the item, if any, is passed in the
|
74
|
+
# 3rd argument of the message.
|
75
|
+
#
|
76
|
+
# === Events
|
77
|
+
#
|
78
|
+
# The following messages are sent by FXList to its target:
|
79
|
+
#
|
80
|
+
# +SEL_CHANGED+:: sent when the current list item changes; the message data is an Integer indicating the index of the current item.
|
81
|
+
# +SEL_COMMAND+:: sent when the current list item changes; the message data is an Integer indicating the index of the current item.
|
82
|
+
# +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
|
83
|
+
# +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
|
84
|
+
# +SEL_LEFTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
|
85
|
+
# +SEL_LEFTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
|
86
|
+
# +SEL_RIGHTBUTTONPRESS+:: sent when the right mouse button goes down; the message data is an FXEvent instance.
|
87
|
+
# +SEL_RIGHTBUTTONRELEASE+:: sent when the right mouse button goes up; the message data is an FXEvent instance.
|
88
|
+
# +SEL_CLICKED+:: sent when a list item is single-clicked; the message data is an Integer indicating the index of the current item.
|
89
|
+
# +SEL_DOUBLECLICKED+:: sent when a list item is double-clicked; the message data is an Integer indicating the index of the current item.
|
90
|
+
# +SEL_TRIPLECLICKED+:: sent when a list item is triple-clicked; the message data is an Integer indicating the index of the current item.
|
91
|
+
# +SEL_SELECTED+:: sent when a list item is selected; the message data is an Integer indicating the index of the selected item.
|
92
|
+
# +SEL_DESELECTED+:: sent when a list item is deselected; the message data is an Integer indicating the index of the deselected item.
|
93
|
+
# +SEL_REPLACED+:: sent when a list item is about to be replaced; the message data is an Integer indicating the index of the item to be replaced.
|
94
|
+
# +SEL_INSERTED+:: sent after a list item is inserted; the message data is an Integer indicating the index of the item that was inserted.
|
95
|
+
# +SEL_DELETED+:: sent when a list item is about to be removed; the message data is an Integer indicating the index of the item to be removed.
|
96
|
+
#
|
97
|
+
# === List styles
|
98
|
+
#
|
99
|
+
# +LIST_EXTENDEDSELECT+:: Extended selection mode allows for drag-selection of ranges of items
|
100
|
+
# +LIST_SINGLESELECT+:: Single selection mode allows up to one item to be selected
|
101
|
+
# +LIST_BROWSESELECT+:: Browse selection mode enforces one single item to be selected at all times
|
102
|
+
# +LIST_MULTIPLESELECT+:: Multiple selection mode is used for selection of individual items
|
103
|
+
# +LIST_AUTOSELECT+:: Automatically select under cursor
|
104
|
+
# +LIST_NORMAL+:: same as +LIST_EXTENDEDSELECT+
|
105
|
+
#
|
106
|
+
# === Message identifiers
|
107
|
+
#
|
108
|
+
# +ID_TIPTIMER+::
|
109
|
+
# +ID_LOOKUPTIMER+::
|
110
|
+
#
|
111
|
+
class FXList < FXScrollArea
|
112
|
+
|
113
|
+
# Number of items in the list [Integer]
|
114
|
+
attr_reader :numItems
|
115
|
+
|
116
|
+
# Number of visible items [Integer]
|
117
|
+
attr_accessor :numVisible
|
118
|
+
|
119
|
+
# Index of current item, or -1 if no current item [Integer]
|
120
|
+
attr_accessor :currentItem
|
121
|
+
|
122
|
+
# Index of anchor item, or -1 if no anchor item [Integer]
|
123
|
+
attr_reader :anchorItem
|
124
|
+
|
125
|
+
# Index of item under the cursor, or -1 if none [Integer]
|
126
|
+
attr_reader :cursorItem
|
127
|
+
|
128
|
+
# Text font [FXFont]
|
129
|
+
attr_accessor :font
|
130
|
+
|
131
|
+
# Normal text color [FXColor]
|
132
|
+
attr_accessor :textColor
|
133
|
+
|
134
|
+
# Selected text background color [FXColor]
|
135
|
+
attr_accessor :selBackColor
|
136
|
+
|
137
|
+
# Selected text color [FXColor]
|
138
|
+
attr_accessor :selTextColor
|
139
|
+
|
140
|
+
# List style [Integer]
|
141
|
+
attr_accessor :listStyle
|
142
|
+
|
143
|
+
# Status line help text [String]
|
144
|
+
attr_accessor :helpText
|
145
|
+
|
146
|
+
# Construct a list with initially no items in it.
|
147
|
+
def initialize(p, target=nil, selector=0, opts=LIST_NORMAL, x=0, y=0, width=0, height=0) # :yields: theList
|
148
|
+
end
|
149
|
+
|
150
|
+
# Return the item at the given _index_; returns a reference to an FXListItem instance.
|
151
|
+
# Raises IndexError if _index_ is out of bounds.
|
152
|
+
def getItem(index) ; end
|
153
|
+
|
154
|
+
# Replace the item at _index_ with a (possibly subclassed) _item_, e.g.
|
155
|
+
#
|
156
|
+
# list.setItem(0, FXListItem.new("inky"))
|
157
|
+
#
|
158
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the list's message target
|
159
|
+
# before the item is replaced.
|
160
|
+
# Raises IndexError if _index_ is out of bounds.
|
161
|
+
# Returns the integer index of the replaced item.
|
162
|
+
def setItem(index, item, notify=false) ; end
|
163
|
+
|
164
|
+
# Replace the _text_, _icon_, and user _data_ for the item at _index_, e.g.
|
165
|
+
#
|
166
|
+
# list.setItem(0, "inky")
|
167
|
+
#
|
168
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the list's message target
|
169
|
+
# before the item is replaced.
|
170
|
+
# Raises IndexError if _index_ is out of bounds.
|
171
|
+
# Returns the integer index of the replaced item.
|
172
|
+
def setItem(index, text, icon=nil, data=nil, notify=false) ; end
|
173
|
+
|
174
|
+
#
|
175
|
+
# Fill list by appending items from array of strings, and return the number
|
176
|
+
# items added.
|
177
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's
|
178
|
+
# message target after the item is added.
|
179
|
+
#
|
180
|
+
def fillItems(strings, icon=nil, ptr=nil, notify=false); end
|
181
|
+
|
182
|
+
# Insert a new (possibly subclassed) _item_ at the given _index_, e.g.
|
183
|
+
#
|
184
|
+
# list.insertItem(1, FXListItem.new("blinky"))
|
185
|
+
#
|
186
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
187
|
+
# after the item is inserted.
|
188
|
+
# Raises IndexError if _index_ is out of bounds.
|
189
|
+
# Returns the integer index of the inserted item.
|
190
|
+
def insertItem(index, item, notify=false) ; end
|
191
|
+
|
192
|
+
# Insert item at _index_ with given _text_, _icon_, and user _data_, e.g.
|
193
|
+
#
|
194
|
+
# list.insertItem(1, "blinky")
|
195
|
+
#
|
196
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
197
|
+
# after the item is inserted.
|
198
|
+
# Raises IndexError if _index_ is out of bounds.
|
199
|
+
# Returns the integer index of the inserted item.
|
200
|
+
def insertItem(index, text, icon=nil, data=nil, notify=false) ; end
|
201
|
+
|
202
|
+
# Append a (possibly subclassed) _item_ to the list, e.g.
|
203
|
+
#
|
204
|
+
# list.appendItem(FXListItem.new("pinky"))
|
205
|
+
#
|
206
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
207
|
+
# after the item is appended.
|
208
|
+
# Returns the integer index of the newly appended item.
|
209
|
+
def appendItem(item, notify=false) ; end
|
210
|
+
|
211
|
+
# Append a new item with given _text_ and optional _icon_ and user _data_, e.g.
|
212
|
+
#
|
213
|
+
# list.appendItem("pinky")
|
214
|
+
#
|
215
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
216
|
+
# after the item is appended.
|
217
|
+
# Returns the integer index of the newly appended item.
|
218
|
+
def appendItem(text, icon=nil, data=nil, notify=false) ; end
|
219
|
+
|
220
|
+
# Prepend a (possibly subclassed) _item_ to the list, e.g.
|
221
|
+
#
|
222
|
+
# list.prependItem(FXListItem.new("clyde"))
|
223
|
+
#
|
224
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
225
|
+
# after the item is prepended.
|
226
|
+
# Returns the integer index of the newly prepended item (which should
|
227
|
+
# always be zero, by definition).
|
228
|
+
def prependItem(item, notify=false) ; end
|
229
|
+
|
230
|
+
# Prepend a new item with given _text_ and optional _icon_ and user _data_, e.g.
|
231
|
+
#
|
232
|
+
# list.prependItem("clyde")
|
233
|
+
#
|
234
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the list's message target
|
235
|
+
# after the item is prepended.
|
236
|
+
# Returns the integer index of the newly prepended item (which should
|
237
|
+
# always be zero, by definition).
|
238
|
+
def prependItem(text, icon=nil, data=nil, notify=false) ; end
|
239
|
+
|
240
|
+
#
|
241
|
+
# Move item from _oldIndex_ to _newIndex_ and return the new index of the
|
242
|
+
# item..
|
243
|
+
# If _notify_ is +true+ and this move causes the current item to change, a
|
244
|
+
# +SEL_CHANGED+ message is sent to the list's message target to indicate this
|
245
|
+
# change in the current item.
|
246
|
+
# Raises IndexError if either _oldIndex_ or _newIndex_ is out of bounds.
|
247
|
+
#
|
248
|
+
def moveItem(newIndex, oldIndex, notify=false); end
|
249
|
+
|
250
|
+
#
|
251
|
+
# Extract item from list and return a reference to the item.
|
252
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the list's
|
253
|
+
# message target before the item is extracted from the list.
|
254
|
+
# Raises IndexError if _index_ is out of bounds.
|
255
|
+
#
|
256
|
+
def extractItem(index, notify=false); end
|
257
|
+
|
258
|
+
# Remove item at _index_ from list.
|
259
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the list's message target
|
260
|
+
# before the item is removed.
|
261
|
+
# Raises IndexError if _index_ is out of bounds.
|
262
|
+
def removeItem(index, notify=false) ; end
|
263
|
+
|
264
|
+
# Remove all items from the list
|
265
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the list's message target
|
266
|
+
# before each item is removed.
|
267
|
+
def clearItems(notify=false) ; end
|
268
|
+
|
269
|
+
# Return width of item at _index_. Raises IndexError if _index_ is out of bounds.
|
270
|
+
def getItemWidth(index) ; end
|
271
|
+
|
272
|
+
# Return height of item at _index_. Raises IndexError if _index_ is out of bounds.
|
273
|
+
def getItemHeight(index) ; end
|
274
|
+
|
275
|
+
# Return index of item at (_x_, _y_), if any
|
276
|
+
def getItemAt(x, y) ; end
|
277
|
+
|
278
|
+
# Return item hit code: 0 no hit; 1 hit the icon; 2 hit the text
|
279
|
+
def hitItem(index, x, y) ; end
|
280
|
+
|
281
|
+
#
|
282
|
+
# Search items by _text_, beginning from item _start_. If the start
|
283
|
+
# item is -1 the search will start at the first item in the list.
|
284
|
+
# Flags may be +SEARCH_FORWARD+ or +SEARCH_BACKWARD+ to control the
|
285
|
+
# search direction; this can be combined with +SEARCH_NOWRAP+ or +SEARCH_WRAP+
|
286
|
+
# to control whether the search wraps at the start or end of the list.
|
287
|
+
# The option +SEARCH_IGNORECASE+ causes a case-insensitive match. Finally,
|
288
|
+
# passing +SEARCH_PREFIX+ causes searching for a prefix of the item name.
|
289
|
+
# Return -1 if no matching item is found.
|
290
|
+
#
|
291
|
+
def findItem(text, start=-1, flags=SEARCH_FORWARD|SEARCH_WRAP) ; end
|
292
|
+
|
293
|
+
#
|
294
|
+
# Search items by associated user _data_, beginning from item _start_.
|
295
|
+
# Returns the integer index of the matching item, or -1 if no match is
|
296
|
+
# found. If the start item is -1 the search will start at the first item in the list.
|
297
|
+
# Flags may be +SEARCH_FORWARD+ or +SEARCH_BACKWARD+ to control the
|
298
|
+
# search direction; this can be combined with +SEARCH_NOWRAP+ or +SEARCH_WRAP+
|
299
|
+
# to control whether the search wraps at the start or end of the list.
|
300
|
+
#
|
301
|
+
def findItemByData(data, start=-1, flags=SEARCH_FORWARD|SEARCH_WRAP); end
|
302
|
+
|
303
|
+
#
|
304
|
+
# Scroll to bring item into view. The argument is either a reference to
|
305
|
+
# an FXListItem instance, or the integer index of an item in the list.
|
306
|
+
# For the latter case, #makeItemVisible raises IndexError if the index
|
307
|
+
# is out of bounds.
|
308
|
+
#
|
309
|
+
def makeItemVisible(itemOrIndex) ; end
|
310
|
+
|
311
|
+
#
|
312
|
+
# Change item text and mark the list's layout as dirty; this is
|
313
|
+
# equivalent to:
|
314
|
+
#
|
315
|
+
# getItem(index).text = text
|
316
|
+
# recalc
|
317
|
+
#
|
318
|
+
# Raises IndexError if _index_ is out of bounds.
|
319
|
+
#
|
320
|
+
def setItemText(index, text) ; end
|
321
|
+
|
322
|
+
#
|
323
|
+
# Return item text; this is equivalent to:
|
324
|
+
#
|
325
|
+
# getItem(index).text
|
326
|
+
#
|
327
|
+
# Raises IndexError if _index_ is out of bounds.
|
328
|
+
#
|
329
|
+
def getItemText(index) ; end
|
330
|
+
|
331
|
+
#
|
332
|
+
# Change item icon and mark the list's layout as dirty; this is equivalent to:
|
333
|
+
#
|
334
|
+
# getItem(index).icon = icon
|
335
|
+
# recalc
|
336
|
+
#
|
337
|
+
# Raises IndexError if _index_ is out of bounds.
|
338
|
+
#
|
339
|
+
def setItemIcon(index, icon, owned=false) ; end
|
340
|
+
|
341
|
+
#
|
342
|
+
# Return item icon, if any. This is equivalent to:
|
343
|
+
#
|
344
|
+
# getItem(index).icon
|
345
|
+
#
|
346
|
+
# Raises IndexError if _index_ is out of bounds.
|
347
|
+
#
|
348
|
+
def getItemIcon(index) ; end
|
349
|
+
|
350
|
+
#
|
351
|
+
# Change item user data; this is equivalent to:
|
352
|
+
#
|
353
|
+
# getItem(index).data = data
|
354
|
+
#
|
355
|
+
# Raises IndexError if _index_ is out of bounds.
|
356
|
+
#
|
357
|
+
def setItemData(index, data) ; end
|
358
|
+
|
359
|
+
#
|
360
|
+
# Return item user data; this is equivalent to:
|
361
|
+
#
|
362
|
+
# getItem(index).data
|
363
|
+
#
|
364
|
+
# Raises IndexError if _index_ is out of bounds.
|
365
|
+
#
|
366
|
+
def getItemData(index) ; end
|
367
|
+
|
368
|
+
#
|
369
|
+
# Return +true+ if item is selected; this is equivalent to:
|
370
|
+
#
|
371
|
+
# getItem(index).selected?
|
372
|
+
#
|
373
|
+
# Raises IndexError if _index_ is out of bounds.
|
374
|
+
#
|
375
|
+
def itemSelected?(index) ; end
|
376
|
+
|
377
|
+
# Return +true+ if item is current. Raises IndexError if _index_ is out of bounds.
|
378
|
+
def itemCurrent?(index) ; end
|
379
|
+
|
380
|
+
# Return +true+ if item is visible. Raises IndexError if _index_ is out of bounds.
|
381
|
+
def itemVisible?(index) ; end
|
382
|
+
|
383
|
+
#
|
384
|
+
# Return +true+ if item is enabled; this is equivalent to:
|
385
|
+
#
|
386
|
+
# getItem(index).enabled?
|
387
|
+
#
|
388
|
+
# Raises IndexError if _index_ is out of bounds.
|
389
|
+
#
|
390
|
+
def itemEnabled?(index) ; end
|
391
|
+
|
392
|
+
# Repaint item. Raises IndexError if _index_ is out of bounds.
|
393
|
+
def updateItem(index) ; end
|
394
|
+
|
395
|
+
#
|
396
|
+
# Enable item. Raises IndexError if _index_ is out of bounds.
|
397
|
+
#
|
398
|
+
def enableItem(index) ; end
|
399
|
+
|
400
|
+
#
|
401
|
+
# Disable item. Raises IndexError if _index_ is out of bounds.
|
402
|
+
#
|
403
|
+
def disableItem(index) ; end
|
404
|
+
|
405
|
+
# Select item.
|
406
|
+
# If _notify_ is +true+, a +SEL_SELECTED+ message is sent to the list's message target
|
407
|
+
# after the item is selected.
|
408
|
+
# Raises IndexError if _index_ is out of bounds.
|
409
|
+
def selectItem(index, notify=false) ; end
|
410
|
+
|
411
|
+
# Deselect item.
|
412
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the list's message target
|
413
|
+
# after the item is deselected.
|
414
|
+
# Raises IndexError if _index_ is out of bounds.
|
415
|
+
def deselectItem(index, notify=false) ; end
|
416
|
+
|
417
|
+
# Toggle item selection state.
|
418
|
+
# If _notify_ is +true+, either a +SEL_SELECTED+ or +SEL_DESELECTED+ message is sent to the list's message target
|
419
|
+
# to indicate the item's new state.
|
420
|
+
# Raises IndexError if _index_ is out of bounds.
|
421
|
+
def toggleItem(index, notify=false) ; end
|
422
|
+
|
423
|
+
# Change current item.
|
424
|
+
# If _notify_ is +true+, a +SEL_CHANGED+ message is sent to the list's message target
|
425
|
+
# after the current item changes.
|
426
|
+
# Raises IndexError if _index_ is out of bounds.
|
427
|
+
def setCurrentItem(index, notify=false) ; end
|
428
|
+
|
429
|
+
# Extend selection from anchor item to _index_.
|
430
|
+
# If _notify_ is +true+, a series of +SEL_SELECTED+ and +SEL_DESELECTED+ messages
|
431
|
+
# are sent to the list's message target as the selected-state of different items changes.
|
432
|
+
# Raises IndexError if _index_ is out of bounds.
|
433
|
+
def extendSelection(index, notify=false) ; end
|
434
|
+
|
435
|
+
# Deselect all items.
|
436
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the list's message
|
437
|
+
# target for all the items that were selected before killSelection was called.
|
438
|
+
def killSelection(notify=false) ; end
|
439
|
+
|
440
|
+
# Sort items using current sort function
|
441
|
+
def sortItems() ; end
|
442
|
+
end
|
443
|
+
end
|