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,31 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# Targa Image
|
4
|
+
#
|
5
|
+
class FXTGAImage < FXImage
|
6
|
+
#
|
7
|
+
# Return the suggested file extension for this image type ("tga").
|
8
|
+
#
|
9
|
+
def FXTGAImage.fileExt; end
|
10
|
+
|
11
|
+
#
|
12
|
+
# Return the MIME type for this image type
|
13
|
+
#
|
14
|
+
def FXTGAImage.mimeType; end
|
15
|
+
|
16
|
+
#
|
17
|
+
# Return an initialized FXTGAImage instance.
|
18
|
+
#
|
19
|
+
# ==== Parameters:
|
20
|
+
#
|
21
|
+
# +a+:: an application instance [FXApp]
|
22
|
+
# +pix+:: a memory buffer formatted in Targa file format [String]
|
23
|
+
# +opts+:: options [Integer]
|
24
|
+
# +width+:: width [Integer]
|
25
|
+
# +height+:: height [Integer]
|
26
|
+
#
|
27
|
+
def initialize(a, pix=nil, opts=0, width=1, height=1) # :yields: theTGAImage
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
@@ -0,0 +1,70 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# Tagged Image File Format (TIFF) Icon
|
4
|
+
#
|
5
|
+
class FXTIFIcon < FXIcon
|
6
|
+
#
|
7
|
+
# Return the suggested file extension for this image type ("tif").
|
8
|
+
#
|
9
|
+
def FXTIFIcon.fileExt; end
|
10
|
+
|
11
|
+
#
|
12
|
+
# Return the MIME type for this image type
|
13
|
+
#
|
14
|
+
def FXTIFIcon.mimeType; end
|
15
|
+
|
16
|
+
# Return +true+ if TIF image file format is supported.
|
17
|
+
def FXTIFIcon.supported? ; end
|
18
|
+
|
19
|
+
# Codec setting [Integer]
|
20
|
+
attr_accessor :codec
|
21
|
+
|
22
|
+
#
|
23
|
+
# Return an initialized FXTIFIcon instance.
|
24
|
+
#
|
25
|
+
# ==== Parameters:
|
26
|
+
#
|
27
|
+
# +a+:: an application instance [FXApp]
|
28
|
+
# +pix+:: a memory buffer formatted in TIFF file format [String]
|
29
|
+
# +clr+:: transparency color [FXColor]
|
30
|
+
# +opts+:: options [Integer]
|
31
|
+
# +width+:: width [Integer]
|
32
|
+
# +height+:: height [Integer]
|
33
|
+
#
|
34
|
+
def initialize(a, pix=nil, clr=0, opts=0, width=1, height=1) # :yields: theTIFIcon
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
#
|
39
|
+
# Load a TIFF file from a stream.
|
40
|
+
# If successful, returns an array containing the image pixel data (as a
|
41
|
+
# String), transparency color, width, height and codec setting.
|
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.fxloadTIF(store); end
|
49
|
+
|
50
|
+
#
|
51
|
+
# Save a TIFF 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
|
+
# +codec+:: codec setting [Integer]
|
62
|
+
#
|
63
|
+
def Fox.fxsaveTIF(store, data, transp, width, height, codec); end
|
64
|
+
|
65
|
+
#
|
66
|
+
# Return +true+ if _store_ (an FXStream instance) contains a TIFF image.
|
67
|
+
#
|
68
|
+
def Fox.fxcheckTIF(store); end
|
69
|
+
end
|
70
|
+
|
@@ -0,0 +1,37 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# Tagged Image File Format (TIFF) Image
|
4
|
+
#
|
5
|
+
class FXTIFImage < FXImage
|
6
|
+
#
|
7
|
+
# Return the suggested file extension for this image type ("tif").
|
8
|
+
#
|
9
|
+
def FXTIFImage.fileExt; end
|
10
|
+
|
11
|
+
#
|
12
|
+
# Return the MIME type for this image type
|
13
|
+
#
|
14
|
+
def FXTIFImage.mimeType; end
|
15
|
+
|
16
|
+
# Return +true+ if TIF image file format is supported.
|
17
|
+
def FXTIFImage.supported? ; end
|
18
|
+
|
19
|
+
# Codec setting [Integer]
|
20
|
+
attr_accessor :codec
|
21
|
+
|
22
|
+
#
|
23
|
+
# Return an initialized FXTIFImage instance.
|
24
|
+
#
|
25
|
+
# ==== Parameters:
|
26
|
+
#
|
27
|
+
# +a+:: an application instance [FXApp]
|
28
|
+
# +pix+:: a memory buffer formatted in TIF file format [String]
|
29
|
+
# +opts+:: options [Integer]
|
30
|
+
# +width+:: width [Integer]
|
31
|
+
# +height+:: height [Integer]
|
32
|
+
#
|
33
|
+
def initialize(a, pix=nil, opts=0, width=1, height=1) # :yields: theTIFImage
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
@@ -0,0 +1,80 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# The FXTabBar layout manager arranges tab items side by side,
|
4
|
+
# and raises the active tab item above the neighboring tab items.
|
5
|
+
# In a the horizontal arrangement, the tab bar can have the tab
|
6
|
+
# items on the top or on the bottom. In the vertical arrangement,
|
7
|
+
# the tabs can be on the left or on the right.
|
8
|
+
# When one of the tab items is pressed, the tab bar's #setCurrent()
|
9
|
+
# method is called with _notify_ of +true+. This in turn causes the tab bar
|
10
|
+
# to send a +SEL_COMMAND+ message to its target.
|
11
|
+
#
|
12
|
+
# === Events
|
13
|
+
#
|
14
|
+
# The following messages are sent by FXTabBar to its target:
|
15
|
+
#
|
16
|
+
# +SEL_COMMAND+::
|
17
|
+
# sent whenever the current tab item changes;
|
18
|
+
# the message data is an integer indicating the new current tab item's index.
|
19
|
+
#
|
20
|
+
# === Tab book options
|
21
|
+
#
|
22
|
+
# +TABBOOK_TOPTABS+:: Tabs on top (default)
|
23
|
+
# +TABBOOK_BOTTOMTABS+:: Tabs on bottom
|
24
|
+
# +TABBOOK_SIDEWAYS+:: Tabs on left
|
25
|
+
# +TABBOOK_LEFTTABS+:: Tabs on left
|
26
|
+
# +TABBOOK_RIGHTTABS+:: Tabs on right
|
27
|
+
# +TABBOOK_NORMAL+:: same as <tt>TABBOOK_TOPTABS</tt>
|
28
|
+
#
|
29
|
+
# === Message identifiers
|
30
|
+
#
|
31
|
+
# +ID_OPEN_ITEM+:: Sent from one of the FXTabItems
|
32
|
+
# +ID_OPEN_FIRST+:: Switch to the first panel
|
33
|
+
# +ID_OPEN_SECOND+:: x
|
34
|
+
# +ID_OPEN_THIRD+:: x
|
35
|
+
# +ID_OPEN_FOURTH+:: x
|
36
|
+
# +ID_OPEN_FIFTH+:: x
|
37
|
+
# +ID_OPEN_SIXTH+:: x
|
38
|
+
# +ID_OPEN_SEVENTH+:: x
|
39
|
+
# +ID_OPEN_EIGHTH+:: x
|
40
|
+
# +ID_OPEN_NINETH+:: x
|
41
|
+
# +ID_OPEN_TENTH+:: x
|
42
|
+
# +ID_OPEN_LAST+:: x
|
43
|
+
#
|
44
|
+
class FXTabBar < FXPacker
|
45
|
+
# Currently active tab item's index [Integer]
|
46
|
+
attr_accessor :current
|
47
|
+
|
48
|
+
# Tab bar style [Integer]
|
49
|
+
attr_accessor :tabStyle
|
50
|
+
|
51
|
+
#
|
52
|
+
# Return an initialized FXTabBar instance.
|
53
|
+
#
|
54
|
+
# ==== Parameters:
|
55
|
+
#
|
56
|
+
# +p+:: the parent window for this tar bar [FXComposite]
|
57
|
+
# +target+:: the message target, if any, for this tar bar [FXObject]
|
58
|
+
# +selector+:: the message identifier for this tab bar [Integer]
|
59
|
+
# +opts+:: tar bar options [Integer]
|
60
|
+
# +x+:: initial x-position [Integer]
|
61
|
+
# +y+:: initial y-position [Integer]
|
62
|
+
# +width+:: initial width [Integer]
|
63
|
+
# +height+:: initial height [Integer]
|
64
|
+
# +padLeft+:: internal padding on the left side, in pixels [Integer]
|
65
|
+
# +padRight+:: internal padding on the right side, in pixels [Integer]
|
66
|
+
# +padTop+:: internal padding on the top side, in pixels [Integer]
|
67
|
+
# +padBottom+:: internal padding on the bottom side, in pixels [Integer]
|
68
|
+
#
|
69
|
+
def initialize(p, target=nil, selector=0, opts=TABBOOK_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_SPACING, padRight=DEFAULT_SPACING, padTop=DEFAULT_SPACING, padBottom=DEFAULT_SPACING) # :yields: theTabBar
|
70
|
+
end
|
71
|
+
|
72
|
+
#
|
73
|
+
# Change currently active tab item; this raises the active tab item
|
74
|
+
# slightly above the neighboring tab items.
|
75
|
+
# If _notify_ is +true+, a +SEL_COMMAND+ message is sent to the tab bar's message target
|
76
|
+
#
|
77
|
+
def setCurrent(index, notify=false); end
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
@@ -0,0 +1,41 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# The tab book layout manager arranges pairs of children;
|
4
|
+
# the even numbered children (0,2,4,...) are usually tab items,
|
5
|
+
# and are placed on the top. The odd numbered children are
|
6
|
+
# usually layout managers, and are placed below; all the odd
|
7
|
+
# numbered children are placed on top of each other, similar
|
8
|
+
# to the switcher widget. When the user presses one of the
|
9
|
+
# tab items, the tab item is raised above the neighboring tabs,
|
10
|
+
# and the corresponding panel is raised to the top.
|
11
|
+
# Thus, a tab book can be used to present many GUI controls
|
12
|
+
# in a small space by placing several panels on top of each
|
13
|
+
# other and using tab items to select the desired panel.
|
14
|
+
# When one of the tab items is pressed, the tab book's #setCurrent method
|
15
|
+
# is called with _notify+=true. This causes the tab book to send a
|
16
|
+
# +SEL_COMMAND+ message to its target.
|
17
|
+
#
|
18
|
+
class FXTabBook < FXTabBar
|
19
|
+
#
|
20
|
+
# Return an initialized FXTabBook instance.
|
21
|
+
#
|
22
|
+
# ==== Parameters:
|
23
|
+
#
|
24
|
+
# +p+:: the parent window for this tar book [FXComposite]
|
25
|
+
# +target+:: the message target, if any, for this tar book [FXObject]
|
26
|
+
# +selector+:: the message identifier for this tab book [Integer]
|
27
|
+
# +opts+:: tar book options [Integer]
|
28
|
+
# +x+:: initial x-position [Integer]
|
29
|
+
# +y+:: initial y-position [Integer]
|
30
|
+
# +width+:: initial width [Integer]
|
31
|
+
# +height+:: initial height [Integer]
|
32
|
+
# +padLeft+:: internal padding on the left side, in pixels [Integer]
|
33
|
+
# +padRight+:: internal padding on the right side, in pixels [Integer]
|
34
|
+
# +padTop+:: internal padding on the top side, in pixels [Integer]
|
35
|
+
# +padBottom+:: internal padding on the bottom side, in pixels [Integer]
|
36
|
+
#
|
37
|
+
def initialize(p, target=nil, selector=0, opts=TABBOOK_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_SPACING, padRight=DEFAULT_SPACING, padTop=DEFAULT_SPACING, padBottom=DEFAULT_SPACING) # :yields: theTabBook
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
@@ -0,0 +1,58 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# A tab item is placed in a tab bar or tab book.
|
4
|
+
# When selected, the tab item sends a message to its
|
5
|
+
# parent, and causes itself to become the active tab,
|
6
|
+
# and raised slightly above the other tabs.
|
7
|
+
# In the tab book, activating a tab item also causes
|
8
|
+
# the corresponding panel to be raised to the top.
|
9
|
+
#
|
10
|
+
# === Events
|
11
|
+
#
|
12
|
+
# The following messages are sent by FXTabItem to its target:
|
13
|
+
#
|
14
|
+
# +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
|
15
|
+
# +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
|
16
|
+
#
|
17
|
+
# === Tab item orientations (which affect border)
|
18
|
+
#
|
19
|
+
# +TAB_TOP+:: Top side tabs
|
20
|
+
# +TAB_LEFT+:: Left side tabs
|
21
|
+
# +TAB_RIGHT+:: Right side tabs
|
22
|
+
# +TAB_BOTTOM+:: Bottom side tabs
|
23
|
+
# +TAB_TOP_NORMAL+:: same as <tt>JUSTIFY_NORMAL|ICON_BEFORE_TEXT|TAB_TOP|FRAME_RAISED|FRAME_THICK</tt>
|
24
|
+
# +TAB_BOTTOM_NORMAL+:: same as <tt>JUSTIFY_NORMAL|ICON_BEFORE_TEXT|TAB_BOTTOM|FRAME_RAISED|FRAME_THICK</tt>
|
25
|
+
# +TAB_LEFT_NORMAL+:: same as <tt>JUSTIFY_LEFT|JUSTIFY_CENTER_Y|ICON_BEFORE_TEXT|TAB_LEFT|FRAME_RAISED|FRAME_THICK</tt>
|
26
|
+
# +TAB_RIGHT_NORMAL+:: same as <tt>JUSTIFY_LEFT|JUSTIFY_CENTER_Y|ICON_BEFORE_TEXT|TAB_RIGHT|FRAME_RAISED|FRAME_THICK</tt>
|
27
|
+
#
|
28
|
+
class FXTabItem < FXLabel
|
29
|
+
|
30
|
+
#
|
31
|
+
# Current tab item orientation, one of +TAB_TOP+, +TAB_LEFT+, +TAB_RIGHT+
|
32
|
+
# or +TAB_BOTTOM+ [Integer].
|
33
|
+
#
|
34
|
+
attr_accessor :tabOrientation
|
35
|
+
|
36
|
+
#
|
37
|
+
# Return an initialized FXTabItem instance.
|
38
|
+
#
|
39
|
+
# ==== Parameters:
|
40
|
+
#
|
41
|
+
# +p+:: the parent tab book (or tab bar) for this tab item [FXTabBar]
|
42
|
+
# +text+:: the text for this tab item [String]
|
43
|
+
# +ic+:: the icon for this tab item, if any [FXIcon]
|
44
|
+
# +opts+:: tab item options [Integer]
|
45
|
+
# +x+:: initial x-position [Integer]
|
46
|
+
# +y+:: initial y-position [Integer]
|
47
|
+
# +width+:: initial width [Integer]
|
48
|
+
# +height+:: initial height [Integer]
|
49
|
+
# +padLeft+:: internal padding on the left side, in pixels [Integer]
|
50
|
+
# +padRight+:: internal padding on the right side, in pixels [Integer]
|
51
|
+
# +padTop+:: internal padding on the top side, in pixels [Integer]
|
52
|
+
# +padBottom+:: internal padding on the bottom side, in pixels [Integer]
|
53
|
+
#
|
54
|
+
def initialize(p, text, ic=nil, opts=TAB_TOP_NORMAL, x=0, y=0, width=0, height=0, padLeft=DEFAULT_PAD, padRight=DEFAULT_PAD, padTop=DEFAULT_PAD, padBottom=DEFAULT_PAD) # :yields: theTabItem
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
@@ -0,0 +1,975 @@
|
|
1
|
+
module Fox
|
2
|
+
#
|
3
|
+
# Represents a cell position in an FXTable.
|
4
|
+
#
|
5
|
+
class FXTablePos
|
6
|
+
# Cell row (zero-based) [Integer]
|
7
|
+
attr_accessor :row
|
8
|
+
|
9
|
+
# Cell column (zero-based) [Integer]
|
10
|
+
attr_accessor :col
|
11
|
+
|
12
|
+
#
|
13
|
+
# Returns an initialized FXTablePos instance.
|
14
|
+
#
|
15
|
+
def initialize; end
|
16
|
+
end
|
17
|
+
|
18
|
+
#
|
19
|
+
# Represents a range of cells in an FXTable.
|
20
|
+
#
|
21
|
+
class FXTableRange
|
22
|
+
# Starting position for this range of cells [FXTablePos]
|
23
|
+
attr_accessor :fm
|
24
|
+
|
25
|
+
# Ending position for this range of cells [FXTablePos]
|
26
|
+
attr_accessor :to
|
27
|
+
|
28
|
+
#
|
29
|
+
# Returns an initialized FXTableRange instance.
|
30
|
+
#
|
31
|
+
def initialize; end
|
32
|
+
end
|
33
|
+
|
34
|
+
#
|
35
|
+
# Represents a particular cell in an FXTable.
|
36
|
+
#
|
37
|
+
class FXTableItem < FXObject
|
38
|
+
|
39
|
+
# Text associated with this cell [String]
|
40
|
+
attr_accessor :text
|
41
|
+
|
42
|
+
# Icon associated with this cell [FXIcon]
|
43
|
+
attr_accessor :icon
|
44
|
+
|
45
|
+
# User data associated with this cell [Object]
|
46
|
+
attr_accessor :data
|
47
|
+
|
48
|
+
# Indicates whether this item has the focus [Boolean]
|
49
|
+
attr_writer :focus
|
50
|
+
|
51
|
+
# Indicates whether this item is selected [Boolean]
|
52
|
+
attr_writer :selected
|
53
|
+
|
54
|
+
# Indicates whether this item is enabled [Boolean]
|
55
|
+
attr_writer :enabled
|
56
|
+
|
57
|
+
# Indicates whether this item is draggable [Boolean]
|
58
|
+
attr_writer :draggable
|
59
|
+
|
60
|
+
#
|
61
|
+
# Indicates how the text in the cell will be justified.
|
62
|
+
# This value is some combination of the horizontal justification
|
63
|
+
# flags +LEFT+, +CENTER_X+ and +RIGHT+, and the vertical
|
64
|
+
# justification flags +TOP+, +CENTER_Y+ and +BOTTOM+.
|
65
|
+
#
|
66
|
+
attr_accessor :justify
|
67
|
+
|
68
|
+
# The icon's position in the cell, relative to the text (one
|
69
|
+
# of +BEFORE+, +AFTER+, +ABOVE+ or +BELOW+) [Integer]
|
70
|
+
attr_accessor :iconPosition
|
71
|
+
|
72
|
+
# Which borders will be drawn for this cell (some combination of
|
73
|
+
# +LBORDER+, +RBORDER+, +TBORDER+ and +BBORDER+) [Integer]
|
74
|
+
attr_accessor :borders
|
75
|
+
|
76
|
+
# The background stipple pattern for this cell [Integer]
|
77
|
+
attr_accessor :stipple
|
78
|
+
|
79
|
+
#
|
80
|
+
# Return an initialized FXTableItem instance.
|
81
|
+
#
|
82
|
+
# ==== Parameters:
|
83
|
+
#
|
84
|
+
# +text+:: the text for this table item [String]
|
85
|
+
# +icon+:: the icon, if any, for this table item [FXIcon]
|
86
|
+
# +data+:: the user data for this table item [Object]
|
87
|
+
#
|
88
|
+
def initialize(text, icon=nil, data=nil); end
|
89
|
+
|
90
|
+
# Return the width of this item (in pixels)
|
91
|
+
def getWidth(table); end
|
92
|
+
|
93
|
+
# Return the height of this item (in pixels)
|
94
|
+
def getHeight(table); end
|
95
|
+
|
96
|
+
# Return true if this item has the focus
|
97
|
+
def hasFocus?; end
|
98
|
+
|
99
|
+
# Return true if this item is selected
|
100
|
+
def selected?; end
|
101
|
+
|
102
|
+
# Return true if this item is enabled
|
103
|
+
def enabled?; end
|
104
|
+
|
105
|
+
# Return true if this item is draggable
|
106
|
+
def draggable?; end
|
107
|
+
|
108
|
+
# Return the text for this table item
|
109
|
+
def to_s
|
110
|
+
text
|
111
|
+
end
|
112
|
+
|
113
|
+
# Change item icon, deleting the previous item icon if it was owned
|
114
|
+
# by this table item.
|
115
|
+
def setIcon(icn, owned=false); end
|
116
|
+
|
117
|
+
# Draw this table item
|
118
|
+
def draw(table, dc, x, y, w, h); end
|
119
|
+
|
120
|
+
# Draw borders
|
121
|
+
def drawBorders(table, dc, x, y, w, h); end
|
122
|
+
|
123
|
+
# Draw content
|
124
|
+
def drawContent(table, dc, x, y, w, h); end
|
125
|
+
|
126
|
+
# Draw hatch pattern
|
127
|
+
def drawPattern(table, dc, x, y, w, h); end
|
128
|
+
|
129
|
+
# Draw background behind the cell
|
130
|
+
def drawBackground(table, dc, x, y, w, h)
|
131
|
+
hg = table.horizontalGridShown? ? 1 : 0
|
132
|
+
vg = table.verticalGridShown? ? 1 : 0
|
133
|
+
dc.fillRectangle(x + vg, y + hg, w - vg, h - hg)
|
134
|
+
end
|
135
|
+
|
136
|
+
#
|
137
|
+
# Create input control for editing this item.
|
138
|
+
# Should return a new instance of some subclass of FXWindow.
|
139
|
+
#
|
140
|
+
def getControlFor(table); end
|
141
|
+
|
142
|
+
#
|
143
|
+
# Set item value from input _control_ (an instance of some subclass
|
144
|
+
# of FXWindow).
|
145
|
+
#
|
146
|
+
def setFromControl(control); end
|
147
|
+
|
148
|
+
# Create the server-side resources associated with this table item
|
149
|
+
def create; end
|
150
|
+
|
151
|
+
# Detach the server-side resources associated with this table item
|
152
|
+
def detach; end
|
153
|
+
|
154
|
+
# Destroy the server-side resources associated with this table item
|
155
|
+
def destroy; end
|
156
|
+
end
|
157
|
+
|
158
|
+
#
|
159
|
+
# The FXTable widget displays a table of items, each with some text and optional
|
160
|
+
# icon. A column Header control provide captions for each column, and a row
|
161
|
+
# Header control provides captions for each row. Columns are resizable by
|
162
|
+
# means of the column Header control if the TABLE_COL_SIZABLE option is passed.
|
163
|
+
# Likewise, rows in the table are resizable if the TABLE_ROW_SIZABLE option is
|
164
|
+
# specified. An entire row (column) can be selected by clicking on the a button
|
165
|
+
# in the row (column) Header control. Passing TABLE_NO_COLSELECT disables column
|
166
|
+
# selection, and passing TABLE_NO_ROWSELECT disables column selection.
|
167
|
+
# When TABLE_COL_RENUMBER is specified, columns are automatically renumbered when
|
168
|
+
# columns are added or removed. Similarly, TABLE_ROW_RENUMBER will cause row numbers
|
169
|
+
# to be recalculated automatically when rows are added or removed.
|
170
|
+
# To disable editing of cells in the table, the TABLE_READONLY can be specified.
|
171
|
+
# Cells in the table may or may not have items in them. When populating a cell
|
172
|
+
# for the first time, an item will be automatically created if necessary. Thus,
|
173
|
+
# a cell in the table takes no space unless it has actual contents.
|
174
|
+
# Moreover, a contiguous, rectangular region of cells in the table may refer to
|
175
|
+
# one single item; in that case, the item will be stretched to cover all the
|
176
|
+
# cells in the region, and no grid lines will be drawn interior to the spanning
|
177
|
+
# item.
|
178
|
+
#
|
179
|
+
# The Table widget issues SEL_SELECTED or SEL_DESELECTED when cells are selected
|
180
|
+
# or deselected, respectively. The table position affected is passed along as the
|
181
|
+
# 3rd parameter of these messages.
|
182
|
+
# Whenever the current (focus) item is changed, a SEL_CHANGED message is sent with
|
183
|
+
# the new table position as a parameter.
|
184
|
+
# When items are added to the table, a SEL_INSERTED message is sent, with the table
|
185
|
+
# range of the newly added cells as the parameter in the message.
|
186
|
+
# When items are removed from the table, a SEL_DELETED message is sent prior to the
|
187
|
+
# removal of the items, and the table range of the removed cells is passed as a parameter.
|
188
|
+
# A SEL_REPLACED message is sent when the contents of a cell are changed, either through
|
189
|
+
# editing or by other means; the parameter is the range of affected cells. This message
|
190
|
+
# is sent prior to the change.
|
191
|
+
# SEL_CLICKED, SEL_DOUBLECLICKED, and SEL_TRIPLECLICKED messages are sent when a cell
|
192
|
+
# is clicked, double-clicked, or triple-clicked, respectively.
|
193
|
+
# A SEL_COMMAND is sent when an enabled item is clicked inside the table.
|
194
|
+
#
|
195
|
+
# === Events
|
196
|
+
#
|
197
|
+
# The following messages are sent by FXTable to its target:
|
198
|
+
#
|
199
|
+
# +SEL_COMMAND+:: sent when a new item is clicked; the message data is an FXTablePos instance indicating the current cell.
|
200
|
+
# +SEL_KEYPRESS+:: sent when a key goes down; the message data is an FXEvent instance.
|
201
|
+
# +SEL_KEYRELEASE+:: sent when a key goes up; the message data is an FXEvent instance.
|
202
|
+
# +SEL_LEFTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
|
203
|
+
# +SEL_LEFTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
|
204
|
+
# +SEL_RIGHTBUTTONPRESS+:: sent when the left mouse button goes down; the message data is an FXEvent instance.
|
205
|
+
# +SEL_RIGHTBUTTONRELEASE+:: sent when the left mouse button goes up; the message data is an FXEvent instance.
|
206
|
+
# +SEL_SELECTED+:: sent when a cell is selected; the message data is an FXTablePos instance indicating the position of the selected cell.
|
207
|
+
# +SEL_DESELECTED+:: sent when a cell is deselected; the message data is an FXTablePos instance indicating the position of the deselected cell.
|
208
|
+
# +SEL_CHANGED+:: sent when the current cell changes; the message data is an FXTablePos instance indicating the current cell.
|
209
|
+
# +SEL_CLICKED+:: sent when a cell is single-clicked; the message data is an FXTablePos instance indicating the current cell.
|
210
|
+
# +SEL_DOUBLECLICKED+:: sent when a cell is double-clicked; the message data is an FXTablePos instance indicating the current cell.
|
211
|
+
# +SEL_TRIPLECLICKED+:: sent when a cell is triple-clicked; the message data is an FXTablePos instance indicating the current cell.
|
212
|
+
# +SEL_DELETED+:: sent when a range of cells is about to be removed; the message data is an FXTableRange instance indicating the cells to be removed.
|
213
|
+
# +SEL_INSERTED+:: sent when a range of cells has been inserted; the message data is an FXTableRange instance indicating the cells inserted.
|
214
|
+
# +SEL_REPLACED+:: sent when a range of cells has been replaced; the message data is an FXTableRange instance indicating the cells replaced.
|
215
|
+
#
|
216
|
+
# === Table options
|
217
|
+
#
|
218
|
+
# +TABLE_COL_SIZABLE+:: Columns are resizable
|
219
|
+
# +TABLE_ROW_SIZABLE+:: Rows are resizable
|
220
|
+
# +TABLE_NO_COLSELECT+:: Disallow column selections
|
221
|
+
# +TABLE_NO_ROWSELECT+:: Disallow row selections
|
222
|
+
# +TABLE_READONLY+:: Table is not editable
|
223
|
+
# +TABLE_COL_RENUMBER+:: Renumber columns
|
224
|
+
# +TABLE_ROW_RENUMBER+:: Renumber rows
|
225
|
+
#
|
226
|
+
# === Message identifiers
|
227
|
+
#
|
228
|
+
# +ID_HORZ_GRID+:: x
|
229
|
+
# +ID_VERT_GRID+:: x
|
230
|
+
# +ID_TOGGLE_EDITABLE+:: x
|
231
|
+
# +ID_DELETE_COLUMN+:: x
|
232
|
+
# +ID_DELETE_ROW+:: x
|
233
|
+
# +ID_INSERT_COLUMN+:: x
|
234
|
+
# +ID_INSERT_ROW+:: x
|
235
|
+
# +ID_SELECT_COLUMN_INDEX+:: x
|
236
|
+
# +ID_SELECT_ROW_INDEX+:: x
|
237
|
+
# +ID_SELECT_COLUMN+:: x
|
238
|
+
# +ID_SELECT_ROW+:: x
|
239
|
+
# +ID_SELECT_CELL+:: x
|
240
|
+
# +ID_SELECT_ALL+:: x
|
241
|
+
# +ID_DESELECT_ALL+:: x
|
242
|
+
# +ID_MOVE_LEFT+:: x
|
243
|
+
# +ID_MOVE_RIGHT+:: x
|
244
|
+
# +ID_MOVE_UP+:: x
|
245
|
+
# +ID_MOVE_DOWN+:: x
|
246
|
+
# +ID_MOVE_HOME+:: x
|
247
|
+
# +ID_MOVE_END+:: x
|
248
|
+
# +ID_MOVE_TOP+:: x
|
249
|
+
# +ID_MOVE_BOTTOM+:: x
|
250
|
+
# +ID_MOVE_PAGEDOWN+:: x
|
251
|
+
# +ID_MOVE_PAGEUP+:: x
|
252
|
+
# +ID_START_INPUT+:: x
|
253
|
+
# +ID_CANCEL_INPUT+:: x
|
254
|
+
# +ID_ACCEPT_INPUT+:: x
|
255
|
+
# +ID_MARK+:: x
|
256
|
+
# +ID_EXTEND+:: x
|
257
|
+
# +ID_CUT_SEL+:: x
|
258
|
+
# +ID_COPY_SEL+:: x
|
259
|
+
# +ID_PASTE_SEL+:: x
|
260
|
+
# +ID_DELETE_SEL+:: x
|
261
|
+
|
262
|
+
class FXTable < FXScrollArea
|
263
|
+
|
264
|
+
# Button in the upper left corner [FXButton]
|
265
|
+
attr_reader :cornerButton
|
266
|
+
|
267
|
+
# Column header control [FXHeader]
|
268
|
+
attr_reader :columnHeader
|
269
|
+
|
270
|
+
# Row header control [FXHeader]
|
271
|
+
attr_reader :rowHeader
|
272
|
+
|
273
|
+
# Number of visible rows [Integer]
|
274
|
+
attr_accessor :visibleRows
|
275
|
+
|
276
|
+
# Number of visible columns [Integer]
|
277
|
+
attr_accessor :visibleColumns
|
278
|
+
|
279
|
+
# Number of rows [Integer]
|
280
|
+
attr_reader :numRows
|
281
|
+
|
282
|
+
# Number of columns [Integer]
|
283
|
+
attr_reader :numColumns
|
284
|
+
|
285
|
+
# Top cell margin, in pixels [Integer]
|
286
|
+
attr_accessor :marginTop
|
287
|
+
|
288
|
+
# Bottom cell margin, in pixels [Integer]
|
289
|
+
attr_accessor :marginBottom
|
290
|
+
|
291
|
+
# Left cell margin, in pixels [Integer]
|
292
|
+
attr_accessor :marginLeft
|
293
|
+
|
294
|
+
# Right cell margin, in pixels [Integer]
|
295
|
+
attr_accessor :marginRight
|
296
|
+
|
297
|
+
# Table style [Integer]
|
298
|
+
attr_accessor :tableStyle
|
299
|
+
|
300
|
+
# The column header height mode is either fixed (LAYOUT_FIX_HEIGHT) or variable.
|
301
|
+
# In variable height mode, the column header will size to fit the contents in it.
|
302
|
+
# In fixed height mode, the size is explicitly set via the _columnHeaderHeight_
|
303
|
+
# attribute.
|
304
|
+
attr_accessor :columnHeaderMode
|
305
|
+
|
306
|
+
# The row header width mode is either fixed (LAYOUT_FIX_WIDTH) or variable.
|
307
|
+
# In variable width mode, the row header will size to fit the contents in it.
|
308
|
+
# In fixed width mode, the size is explicitly set via the _rowHeaderWidth_
|
309
|
+
# attribute.
|
310
|
+
attr_accessor :rowHeaderMode
|
311
|
+
|
312
|
+
# Row header font [FXFont]
|
313
|
+
attr_accessor :rowHeaderFont
|
314
|
+
|
315
|
+
# Column header font [FXFont]
|
316
|
+
attr_accessor :columnHeaderFont
|
317
|
+
|
318
|
+
# The fixed column header height, if _columnHeaderMode_ is +LAYOUT_FIX_HEIGHT+.
|
319
|
+
attr_accessor :columnHeaderHeight
|
320
|
+
|
321
|
+
# The fixed row header width, if _rowHeaderMode_ is +LAYOUT_FIX_WIDTH+.
|
322
|
+
attr_accessor :rowHeaderWidth
|
323
|
+
|
324
|
+
# Default column width, in pixels [Integer]
|
325
|
+
attr_accessor :defColumnWidth
|
326
|
+
|
327
|
+
# Default row height, in pixels [Integer]
|
328
|
+
attr_accessor :defRowHeight
|
329
|
+
|
330
|
+
# Row number for current cell [Integer]
|
331
|
+
attr_reader :currentRow
|
332
|
+
|
333
|
+
# Column number for current cell [Integer]
|
334
|
+
attr_reader :currentColumn
|
335
|
+
|
336
|
+
# Row number for anchor cell [Integer]
|
337
|
+
attr_reader :anchorRow
|
338
|
+
|
339
|
+
# Column number for anchor cell [Integer]
|
340
|
+
attr_reader :anchorColumn
|
341
|
+
|
342
|
+
# Starting row number for selection, or -1 if there is no selection [Integer]
|
343
|
+
attr_reader :selStartRow
|
344
|
+
|
345
|
+
# Starting column number for selection, or -1 if there is no selection [Integer]
|
346
|
+
attr_reader :selStartColumn
|
347
|
+
|
348
|
+
# Ending row number for selection, or -1 if there is no selection [Integer]
|
349
|
+
attr_reader :selEndRow
|
350
|
+
|
351
|
+
# Ending column number for selection, or -1 if there is no selection [Integer]
|
352
|
+
attr_reader :selEndColumn
|
353
|
+
|
354
|
+
# Text font [FXFont]
|
355
|
+
attr_accessor :font
|
356
|
+
|
357
|
+
# Text color [FXColor]
|
358
|
+
attr_accessor :textColor
|
359
|
+
|
360
|
+
# Base GUI color [FXColor]
|
361
|
+
attr_accessor :baseColor
|
362
|
+
|
363
|
+
# Highlight color [FXColor]
|
364
|
+
attr_accessor :hiliteColor
|
365
|
+
|
366
|
+
# Shadow color [FXColor]
|
367
|
+
attr_accessor :shadowColor
|
368
|
+
|
369
|
+
# Border color [FXColor]
|
370
|
+
attr_accessor :borderColor
|
371
|
+
|
372
|
+
# Background color for selected cell(s) [FXColor]
|
373
|
+
attr_accessor :selBackColor
|
374
|
+
|
375
|
+
# Text color for selected cell(s) [FXColor]
|
376
|
+
attr_accessor :selTextColor
|
377
|
+
|
378
|
+
# Grid color [FXColor]
|
379
|
+
attr_accessor :gridColor
|
380
|
+
|
381
|
+
# Stipple color [FXColor]
|
382
|
+
attr_accessor :stippleColor
|
383
|
+
|
384
|
+
# Cell border color [FXColor]
|
385
|
+
attr_accessor :cellBorderColor
|
386
|
+
|
387
|
+
# Cell border width, in pixels [Integer]
|
388
|
+
attr_accessor :cellBorderWidth
|
389
|
+
|
390
|
+
# Status line help text [String]
|
391
|
+
attr_accessor :helpText
|
392
|
+
|
393
|
+
# Returns the drag type for CSV data
|
394
|
+
def FXTable.csvType; end
|
395
|
+
|
396
|
+
# Returns the drag type name for CSV data
|
397
|
+
def FXTable.csvTypeName; end
|
398
|
+
|
399
|
+
#
|
400
|
+
# Construct a new FXTable instance.
|
401
|
+
# The table is initially empty, and reports a default size based on
|
402
|
+
# the scroll areas's scrollbar placement policy.
|
403
|
+
#
|
404
|
+
# ==== Parameters:
|
405
|
+
#
|
406
|
+
# +p+:: the parent window for this table [FXComposite]
|
407
|
+
# +target+:: the message target (if any) for this table [FXObject]
|
408
|
+
# +selector+:: the message identifier for this table [Integer]
|
409
|
+
# +opts+:: table options [Integer]
|
410
|
+
# +x+:: initial x-position [Integer]
|
411
|
+
# +y+:: initial y-position [Integer]
|
412
|
+
# +width+:: initial width [Integer]
|
413
|
+
# +height+:: initial height [Integer]
|
414
|
+
# +padLeft+:: internal padding on the left side, in pixels [Integer]
|
415
|
+
# +padRight+:: internal padding on the right side, in pixels [Integer]
|
416
|
+
# +padTop+:: internal padding on the top side, in pixels [Integer]
|
417
|
+
# +padBottom+:: internal padding on the bottom side, in pixels [Integer]
|
418
|
+
#
|
419
|
+
def initialize(p, target=nil, selector=0, opts=0, x=0, y=0, width=0, height=0, padLeft=DEFAULT_MARGIN, padRight=DEFAULT_MARGIN, padTop=DEFAULT_MARGIN, padBottom=DEFAULT_MARGIN) # :yields: theTable
|
420
|
+
end
|
421
|
+
|
422
|
+
# Set visibility of horizontal grid to +true+ or +false+.
|
423
|
+
def horizontalGridShown=(vis); end
|
424
|
+
|
425
|
+
# Return +true+ if horizontal grid is shown.
|
426
|
+
def horizontalGridShown? ; end
|
427
|
+
|
428
|
+
# Set visibility of vertical grid to +true+ or +false+.
|
429
|
+
def verticalGridShown=(vis); end
|
430
|
+
|
431
|
+
# Is vertical grid shown?
|
432
|
+
def verticalGridShown? ; end
|
433
|
+
|
434
|
+
#
|
435
|
+
# Show or hide horizontal grid.
|
436
|
+
# Note that this is equivalent to the #horizontalGridShown=() method.
|
437
|
+
#
|
438
|
+
def showHorzGrid(on=true) ; end
|
439
|
+
|
440
|
+
#
|
441
|
+
# Show or hide vertical grid.
|
442
|
+
# Note that this is equivalent to the #verticalGridShown=() method.
|
443
|
+
#
|
444
|
+
def showVertGrid(on=true) ; end
|
445
|
+
|
446
|
+
# Set editability of this table to +true+ or +false+.
|
447
|
+
def editable=(edit); end
|
448
|
+
|
449
|
+
# Return +true+ if this table is editable.
|
450
|
+
def editable? ; end
|
451
|
+
|
452
|
+
#
|
453
|
+
# Start input mode for the cell at the given position.
|
454
|
+
# An input control is created which is used to edit the cell;
|
455
|
+
# it is filled by the original item's contents if the cell contained
|
456
|
+
# an item. You can enter input mode also by sending the table an
|
457
|
+
# <tt>ID_START_INPUT</tt> message.
|
458
|
+
#
|
459
|
+
def startInput(row, col); end
|
460
|
+
|
461
|
+
#
|
462
|
+
# Cancel input mode. The input control is immediately deleted
|
463
|
+
# and the cell will retain its old value. You can also cancel
|
464
|
+
# input mode by sending the table an <tt>ID_CANCEL_INPUT</tt> message.
|
465
|
+
#
|
466
|
+
def cancelInput(); end
|
467
|
+
|
468
|
+
#
|
469
|
+
# End input mode and accept the new value from the control.
|
470
|
+
# The item in the cell will be set to the value from the control,
|
471
|
+
# and the control will be deleted. If +true+ is passed, a +SEL_REPLACED+
|
472
|
+
# callback will be generated to signify to the target that this call
|
473
|
+
# has a new value. You can also accept the input by sending the table
|
474
|
+
# an <tt>ID_ACCEPT_INPUT</tt> message.
|
475
|
+
#
|
476
|
+
def acceptInput(notify=false); end
|
477
|
+
|
478
|
+
#
|
479
|
+
# Determine row containing _y_.
|
480
|
+
# Returns -1 if _y_ is above the first row, and _numRows_ if _y_ is below the last row.
|
481
|
+
# Otherwise, returns the row in the table containing _y_.
|
482
|
+
#
|
483
|
+
def rowAtY(y) ; end
|
484
|
+
|
485
|
+
#
|
486
|
+
# Determine column containing _x_.
|
487
|
+
# Returns -1 if _x_ is to the left of the first column, and _numColumns_ if _x_ is
|
488
|
+
# to the right of the last column. Otherwise, returns the column in the table
|
489
|
+
# containing _x_.
|
490
|
+
#
|
491
|
+
def colAtX(x) ; end
|
492
|
+
|
493
|
+
# Return the item (a reference to an FXTableItem) at the given _row_ and _column_.
|
494
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
495
|
+
def getItem(row, column) ; end
|
496
|
+
|
497
|
+
# Replace the item at the given _row_ and _column_ with a (possibly subclassed) _item_.
|
498
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
499
|
+
def setItem(row, column, item) ; end
|
500
|
+
|
501
|
+
#
|
502
|
+
# Resize the table content to _numRows_ rows and _numCols_ columns.
|
503
|
+
# Note that all existing items in the table will be destroyed and new
|
504
|
+
# items will be constructed.
|
505
|
+
# If _notify_ is +true+, then
|
506
|
+
# * a +SEL_DELETED+ message will be sent to the table's message target
|
507
|
+
# indicating which cells (if any) are about to be destroyed as a result of the resize;
|
508
|
+
# * a +SEL_INSERTED+ message will be sent to the table's message target
|
509
|
+
# indicating which cells (if any) were added as a result of the resize; and,
|
510
|
+
# * a +SEL_CHANGED+ message will be sent to the table's message target
|
511
|
+
# indicating the new current cell.
|
512
|
+
#
|
513
|
+
# Raises ArgError if either _numRows_ or _numCols_ is less than zero.
|
514
|
+
#
|
515
|
+
def setTableSize(numRows, numCols, notify=false) ; end
|
516
|
+
|
517
|
+
#
|
518
|
+
# Insert _numRows_ rows beginning at the specified _row_ number.
|
519
|
+
# If _row_ is equal to the number of rows in the table, the new
|
520
|
+
# rows are added to the bottom of the table.
|
521
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the table's
|
522
|
+
# message target for each cell that is inserted.
|
523
|
+
# Raises IndexError if _row_ is out of bounds.
|
524
|
+
#
|
525
|
+
def insertRows(row, numRows=1, notify=false) ; end
|
526
|
+
|
527
|
+
#
|
528
|
+
# Insert _numColumns_ columns beginning at the specified _column_ number.
|
529
|
+
# If _column_ is equal to the number of columns in the table, the
|
530
|
+
# new columns are added to the right of the table.
|
531
|
+
# If _notify_ is +true+, a +SEL_INSERTED+ message is sent to the table's
|
532
|
+
# message target for each cell that is inserted.
|
533
|
+
# Raises IndexError if _column_ is out of bounds.
|
534
|
+
#
|
535
|
+
def insertColumns(column, numColumns=1, notify=false) ; end
|
536
|
+
|
537
|
+
#
|
538
|
+
# Remove the _nr_ rows starting at the specified _row_.
|
539
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
|
540
|
+
# message target for each cell that is removed.
|
541
|
+
# Raises IndexError if _row_ is less than zero, or if _row_ + _nr_
|
542
|
+
# is greater than the current number of table rows.
|
543
|
+
#
|
544
|
+
def removeRows(row, nr=1, notify=false) ; end
|
545
|
+
|
546
|
+
#
|
547
|
+
# Remove the _nc_ columns starting at the specified _column_.
|
548
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
|
549
|
+
# message target for each cell that is removed.
|
550
|
+
# Raises IndexError if _column_ is less than zero, or if
|
551
|
+
# _column_ + _nc_ is greater than the current number of table columns.
|
552
|
+
#
|
553
|
+
def removeColumns(column, nc=1, notify=false) ; end
|
554
|
+
|
555
|
+
#
|
556
|
+
# Extract item from table and return a reference to it.
|
557
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
|
558
|
+
# message target before this cell is removed.
|
559
|
+
# Raises IndexError if either _row_ or _col_ is out of bounds.
|
560
|
+
#
|
561
|
+
def extractItem(r, c, notify=false); end
|
562
|
+
|
563
|
+
#
|
564
|
+
# Remove item at (_row_, _col_), replacing it with +nil+.
|
565
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
|
566
|
+
# message target before this cell is removed.
|
567
|
+
# Raises IndexError if either _row_ or _col_ is out of bounds.
|
568
|
+
#
|
569
|
+
def removeItem(row, col, notify=false) ; end
|
570
|
+
|
571
|
+
#
|
572
|
+
# Remove all cells in the specified range of rows and columns.
|
573
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
|
574
|
+
# message target before each cell is removed.
|
575
|
+
# Raises IndexError if _startrow_, _endrow_, _startcol_ or
|
576
|
+
# _endcol_ is out of bounds.
|
577
|
+
#
|
578
|
+
def removeRange(startrow, endrow, startcol, endcol, notify=false); end
|
579
|
+
|
580
|
+
#
|
581
|
+
# Remove all items from table.
|
582
|
+
# If _notify_ is +true+, a +SEL_DELETED+ message is sent to the table's
|
583
|
+
# message target before the cells are removed.
|
584
|
+
#
|
585
|
+
def clearItems(notify=false); end
|
586
|
+
|
587
|
+
# Scroll to make cell at (_row_, _column_) fully visible.
|
588
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
589
|
+
def makePositionVisible(row, column) ; end
|
590
|
+
|
591
|
+
# Returns +true+ if the cell at position (_row_, _column_) is visible.
|
592
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
593
|
+
def itemVisible?(row, column) ; end
|
594
|
+
|
595
|
+
# Set column width.
|
596
|
+
# Raises IndexError if _column_ is out of bounds.
|
597
|
+
def setColumnWidth(column, columnWidth) ; end
|
598
|
+
|
599
|
+
# Get column width.
|
600
|
+
# Raises IndexError if _column_ is out of bounds.
|
601
|
+
def getColumnWidth(column) ; end
|
602
|
+
|
603
|
+
# Set row height.
|
604
|
+
# Raises IndexError if _row_ is out of bounds.
|
605
|
+
def setRowHeight(row, rowHeight) ; end
|
606
|
+
|
607
|
+
# Get row height.
|
608
|
+
# Raises IndexError if _row_ is out of bounds.
|
609
|
+
def getRowHeight(row) ; end
|
610
|
+
|
611
|
+
# Get x-coordinate of column.
|
612
|
+
# Raises IndexError if _column_ is out of bounds.
|
613
|
+
def getColumnX(column) ; end
|
614
|
+
|
615
|
+
# Get y-coordinate of row.
|
616
|
+
# Raises IndexError if _row_ is out of bounds.
|
617
|
+
def getRowY(row) ; end
|
618
|
+
|
619
|
+
# Return minimum row height for row _r_.
|
620
|
+
# Raises IndexError if _r_ is out of bounds.
|
621
|
+
def minRowHeight(r); end
|
622
|
+
|
623
|
+
# Return minimum column width for column _c_.
|
624
|
+
# Raises IndexError if _c_ is out of bounds.
|
625
|
+
def minColumnWidth(c); end
|
626
|
+
|
627
|
+
#
|
628
|
+
# Fit row heights to contents, for the _nr_ rows beginning with row index
|
629
|
+
# _row_.
|
630
|
+
#
|
631
|
+
def fitRowsToContents(row, nr=1); end
|
632
|
+
|
633
|
+
#
|
634
|
+
# Fit column widths to contents, for the _nc_ columns beginning with
|
635
|
+
# column index _col_.
|
636
|
+
#
|
637
|
+
def fitColumnsToContents(col, nc=1); end
|
638
|
+
|
639
|
+
# Set column header at _index_ to _text_.
|
640
|
+
# Raises IndexError if _index_ is out of bounds.
|
641
|
+
def setColumnText(index, text); end
|
642
|
+
|
643
|
+
# Return text of column header at _index_.
|
644
|
+
# Raises IndexError if _index_ is out of bounds.
|
645
|
+
def getColumnText(index); end
|
646
|
+
|
647
|
+
# Set row header at _index_ to _text_.
|
648
|
+
# Raises IndexError if _index_ is out of bounds.
|
649
|
+
def setRowText(index, text); end
|
650
|
+
|
651
|
+
# Return text of row header at _index_.
|
652
|
+
# Raises IndexError if _index_ is out of bounds.
|
653
|
+
def getRowText(index); end
|
654
|
+
|
655
|
+
# Change column header icon.
|
656
|
+
# Raises IndexError if _index_ is out of bounds.
|
657
|
+
def setColumnIcon(FXint index,FXIcon* icon);
|
658
|
+
|
659
|
+
# Return icon of column header at _index_.
|
660
|
+
# Raises IndexError if _index_ is out of bounds.
|
661
|
+
def getColumnIcon(index); end
|
662
|
+
|
663
|
+
# Change row header icon.
|
664
|
+
# Raises IndexError if _index_ is out of bounds.
|
665
|
+
def setRowIcon(index, icon); end
|
666
|
+
|
667
|
+
# Return icon of row header at _index_.
|
668
|
+
# Raises IndexError if _index_ is out of bounds.
|
669
|
+
def getRowIcon(index); end
|
670
|
+
|
671
|
+
# Change column header icon position, e.g. FXHeaderItem::BEFORE, etc.
|
672
|
+
# Raises IndexError if _index_ is out of bounds.
|
673
|
+
def setColumnIconPosition(index, mode); end
|
674
|
+
|
675
|
+
# Return icon position of column header at _index_.
|
676
|
+
# Raises IndexError if _index_ is out of bounds.
|
677
|
+
def getColumnIconPosition(index); end
|
678
|
+
|
679
|
+
# Change row header icon position, e.g. FXHeaderItem::BEFORE, etc.
|
680
|
+
# Raises IndexError if _index_ is out of bounds.
|
681
|
+
def setRowIconPosition(index, mode); end
|
682
|
+
|
683
|
+
# Return icon position of row header at _index_.
|
684
|
+
# Raises IndexError if _index_ is out of bounds.
|
685
|
+
def getRowIconPosition(index); end
|
686
|
+
|
687
|
+
# Change column header justify, e.g. FXHeaderItem::RIGHT, etc.
|
688
|
+
# Raises IndexError if _index_ is out of bounds.
|
689
|
+
def setColumnJustify(index, justify); end
|
690
|
+
|
691
|
+
# Return justify of column header at _index_.
|
692
|
+
# Raises IndexError if _index_ is out of bounds.
|
693
|
+
def getColumnJustify(index); end
|
694
|
+
|
695
|
+
# Change row header justify, e.g. FXHeaderItem::RIGHT, etc.
|
696
|
+
# Raises IndexError if _index_ is out of bounds.
|
697
|
+
def setRowJustify(index, justify); end
|
698
|
+
|
699
|
+
# Return justify of row header at _index_.
|
700
|
+
# Raises IndexError if _index_ is out of bounds.
|
701
|
+
def getRowJustify(index); end
|
702
|
+
|
703
|
+
#
|
704
|
+
# Modify cell text for item at specified _row_ and _col_.
|
705
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
|
706
|
+
# message target before the item's text is changed..
|
707
|
+
# Raises IndexError if either _row_ or _col_ is out of bounds.
|
708
|
+
#
|
709
|
+
def setItemText(row, col, text, notify=false) ; end
|
710
|
+
|
711
|
+
# Return cell text for item at specified _row_ and _column_.
|
712
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
713
|
+
def getItemText(row, column) ; end
|
714
|
+
|
715
|
+
#
|
716
|
+
# Modify cell icon, deleting the old icon if it was owned.
|
717
|
+
# If _notify_ is +true+, a +SEL_REPLACED+ message is sent to the table's
|
718
|
+
# message target before the item's icon is changed..
|
719
|
+
# Raises IndexError if either _row_ or _col_ is out of bounds.
|
720
|
+
#
|
721
|
+
def setItemIcon(row, col, icon, notify=false) ; end
|
722
|
+
|
723
|
+
# Return item icon.
|
724
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
725
|
+
def getItemIcon(row, column) ; end
|
726
|
+
|
727
|
+
# Modify cell user data.
|
728
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
729
|
+
def setItemData(row, column, data) ; end
|
730
|
+
|
731
|
+
# Return cell user data.
|
732
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
733
|
+
def getItemData(row, column) ; end
|
734
|
+
|
735
|
+
#
|
736
|
+
# Extract the text from all the cells in the specified range and
|
737
|
+
# return the result as a string.
|
738
|
+
# Within the result string, each column's text is delimited by
|
739
|
+
# the string specified by _cs_, and each row is delimited by
|
740
|
+
# the string specified by _rs_.
|
741
|
+
# To reverse this operation (i.e. set the table cells' text
|
742
|
+
# from a string), see #overlayText.
|
743
|
+
# Raises IndexError if any of _startrow_, _endrow_, _startcol_
|
744
|
+
# or _endcol_ is out of bounds.
|
745
|
+
#
|
746
|
+
# ==== Parameters:
|
747
|
+
#
|
748
|
+
# +startrow+:: the starting row for the range [Integer]
|
749
|
+
# +endrow+:: the ending row for the range [Integer]
|
750
|
+
# +startcol+:: the starting column for the range [Integer]
|
751
|
+
# +endcol+:: the ending column for the range [Integer]
|
752
|
+
# +cs+:: the string to insert at each column break [String]
|
753
|
+
# +rs+:: the string to insert at each row break [String]
|
754
|
+
#
|
755
|
+
def extractText(startrow, endrow, startcol, endcol, cs="\t", rs="\n"); end
|
756
|
+
|
757
|
+
#
|
758
|
+
# Overlay the text for the cells in the specified range with
|
759
|
+
# the fields specified in _text_.
|
760
|
+
# Within the _text_ string, each column's text should delimited by
|
761
|
+
# the character specified by _cs_, and each row should be delimited by
|
762
|
+
# the character specified by _rs_.
|
763
|
+
# To reverse this operation (i.e. extract the table cells' text
|
764
|
+
# into a string), see #extractText.
|
765
|
+
# Raises IndexError if any of _startrow_, _endrow_, _startcol_
|
766
|
+
# or _endcol_ is out of bounds.
|
767
|
+
#
|
768
|
+
# ==== Parameters:
|
769
|
+
#
|
770
|
+
# +startrow+:: the starting row for the range [Integer]
|
771
|
+
# +endrow+:: the ending row for the range [Integer]
|
772
|
+
# +startcol+:: the starting column for the range [Integer]
|
773
|
+
# +endcol+:: the ending column for the range [Integer]
|
774
|
+
# +text+:: the text containing the new cell text [String]
|
775
|
+
# +cs+:: the character to insert at each column break [String]
|
776
|
+
# +rs+:: the character to insert at each row break [String]
|
777
|
+
#
|
778
|
+
def overlayText(startrow, endrow, startcol, endcol, text, cs="\t", rs="\n", notify=false); end
|
779
|
+
|
780
|
+
#
|
781
|
+
# Determine the number of rows and columns in a block of text
|
782
|
+
# where columns are separated by characters from the set _cs_, and rows
|
783
|
+
# are separated by characters from the set _rs_.
|
784
|
+
# Return a two-element array containing the number of rows and
|
785
|
+
# columns, respectively.
|
786
|
+
#
|
787
|
+
def countText(text, cs="\t,", rs="\n"); end
|
788
|
+
|
789
|
+
# Return +true+ if the cell at position (_r_, _c_) is a spanning cell.
|
790
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
791
|
+
def itemSpanning?(r, c); end
|
792
|
+
|
793
|
+
#
|
794
|
+
# Repaint cells between grid lines (_startRow_, _endRow_) and grid lines
|
795
|
+
# (_startCol_, _endCol_).
|
796
|
+
# Raises IndexError if any of the starting or ending grid lines is out of bounds.
|
797
|
+
#
|
798
|
+
def updateRange(startRow, endRow, startCol, endCol) ; end
|
799
|
+
|
800
|
+
# Repaint cell.
|
801
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
802
|
+
def updateItem(row, column) ; end
|
803
|
+
|
804
|
+
# Enable cell.
|
805
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
806
|
+
def enableItem(row, column) ; end
|
807
|
+
|
808
|
+
# Disable cell.
|
809
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
810
|
+
def disableItem(row, column) ; end
|
811
|
+
|
812
|
+
# Returns +true+ if the cell at position (_row_, _column_) is enabled.
|
813
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
814
|
+
def itemEnabled?(row, column) ; end
|
815
|
+
|
816
|
+
#
|
817
|
+
# Change item justification for the cell at (_r_, _c_).
|
818
|
+
# Horizontal justification is controlled by passing
|
819
|
+
# FXTableItem::RIGHT, FXTableItem::LEFT, or FXTableItem::CENTER_X.
|
820
|
+
# Vertical justification is controlled by FXTableItem::TOP, FXTableItem::BOTTOM,
|
821
|
+
# or FXTableItem::CENTER_Y.
|
822
|
+
# The default is a combination of FXTableItem::RIGHT and FXTableItem::CENTER_Y.
|
823
|
+
#
|
824
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
825
|
+
#
|
826
|
+
def setItemJustify(r, c, justify); end
|
827
|
+
|
828
|
+
# Return item justification for the cell at (_r_, _c_).
|
829
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
830
|
+
def getItemJustify(r, c); end
|
831
|
+
|
832
|
+
#
|
833
|
+
# Change relative position of icon and text of item at (_r_, _c_).
|
834
|
+
# Passing FXTableItem::BEFORE or FXTableItem::AFTER places the icon
|
835
|
+
# before or after the text, and passing FXTableItem::ABOVE or
|
836
|
+
# FXTableItem::BELOW places it above or below the text, respectively.
|
837
|
+
# The default is 0 which places the text on top of the icon.
|
838
|
+
#
|
839
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
840
|
+
#
|
841
|
+
def setItemIconPosition(r, c, mode); end
|
842
|
+
|
843
|
+
# Return the relative position of the icon and text for the cell at (_r_, _c_).
|
844
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
845
|
+
def getItemIconPosition(r, c); end
|
846
|
+
|
847
|
+
#
|
848
|
+
# Change item borders style for the item at (_r_, _c_).
|
849
|
+
# Borders on each side of the item can be turned
|
850
|
+
# controlled individually using FXTableItem::LBORDER, FXTableItem::RBORDER,
|
851
|
+
# FXTableItem::TBORDER and FXTableItem::BBORDER.
|
852
|
+
#
|
853
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
854
|
+
#
|
855
|
+
def setItemBorders(r, c, borders); end
|
856
|
+
|
857
|
+
# Return the border style for the cell at (_r_, _c_).
|
858
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
859
|
+
def getItemBorders(r, c); end
|
860
|
+
|
861
|
+
# Set the background stipple style for the cell at (_r_, _c_).
|
862
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
863
|
+
def setItemStipple(r, c, pat); end
|
864
|
+
|
865
|
+
# Return the background stipple style for the cell at (_r_, _c_).
|
866
|
+
# Raises IndexError if either _r_ or _c_ is out of bounds.
|
867
|
+
def getItemStipple(r, c); end
|
868
|
+
|
869
|
+
# Change current cell.
|
870
|
+
# If _notify_ is +true+, a +SEL_CHANGED+ message is sent to the table's
|
871
|
+
# message target after the current item changes.
|
872
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
873
|
+
def setCurrentItem(row, column, notify=false) ; end
|
874
|
+
|
875
|
+
# Returns +true+ if the cell at position (_row_, _column_) is the current cell.
|
876
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
877
|
+
def itemCurrent?(row, column) ; end
|
878
|
+
|
879
|
+
# Change anchored cell.
|
880
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
881
|
+
def setAnchorItem(row, column) ; end
|
882
|
+
|
883
|
+
# Returns +true+ if the cell at position (_row_, _column_) is selected.
|
884
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
885
|
+
def itemSelected?(row, column) ; end
|
886
|
+
|
887
|
+
# Return +true+ if the specified row of cells is selected.
|
888
|
+
# Raises IndexError if _r_ is out of bounds.
|
889
|
+
def rowSelected?(r); end
|
890
|
+
|
891
|
+
# Return +true+ if the specified column of cells is selected.
|
892
|
+
# Raises IndexError if _c_ is out of bounds.
|
893
|
+
def columnSelected?(c); end
|
894
|
+
|
895
|
+
# Return +true+ if any cells are selected.
|
896
|
+
def anythingSelected?; end
|
897
|
+
|
898
|
+
# Select a row of cells.
|
899
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
|
900
|
+
# target for each previously selected cell that becomes deselected as a result of
|
901
|
+
# this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
|
902
|
+
# message target for each newly-selected cell.
|
903
|
+
# Raises IndexError if _row_ is out of bounds.
|
904
|
+
def selectRow(row, notify=false); end
|
905
|
+
|
906
|
+
# Select a column of cells.
|
907
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
|
908
|
+
# target for each previously selected cell that becomes deselected as a result of
|
909
|
+
# this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
|
910
|
+
# message target for each newly-selected cell.
|
911
|
+
# Raises IndexError if _col_ is out of bounds.
|
912
|
+
def selectColumn(col, notify=false); end
|
913
|
+
|
914
|
+
# Select range.
|
915
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's message
|
916
|
+
# target for each previously selected cell that becomes deselected as a result of
|
917
|
+
# this operation. Likewise, a +SEL_SELECTED+ message is sent to the table's
|
918
|
+
# message target for each newly-selected cell.
|
919
|
+
# Raises IndexError if _startRow_, _endRow_, _startColumn_ or _endColumn_ is out of bounds.
|
920
|
+
def selectRange(startRow, endRow, startColumn, endColumn, notify=false) ; end
|
921
|
+
|
922
|
+
# Extend selection.
|
923
|
+
# If _notify_ is +true+, a series of +SEL_SELECTED+ and +SEL_DESELECTED+ messages are sent to the table's message target
|
924
|
+
# after each affected item is selected or deselected.
|
925
|
+
# Raises IndexError if either _row_ or _column_ is out of bounds.
|
926
|
+
def extendSelection(row, column, notify=false) ; end
|
927
|
+
|
928
|
+
# Kill selection.
|
929
|
+
# If _notify_ is +true+, a +SEL_DESELECTED+ message is sent to the table's
|
930
|
+
# message target for each cell that was previously selected.
|
931
|
+
def killSelection(notify=false) ; end
|
932
|
+
|
933
|
+
#
|
934
|
+
# Change cell background color.
|
935
|
+
# The values for _row_ and _column_ are either zero or one.
|
936
|
+
# If the value is zero, this background color is used for even-numbered
|
937
|
+
# rows (columns). If the value is one, this background color is used
|
938
|
+
# for odd-numbered rows (columns).
|
939
|
+
# See also #getCellColor.
|
940
|
+
#
|
941
|
+
def setCellColor(row, column, color) ; end
|
942
|
+
|
943
|
+
#
|
944
|
+
# Obtain cell background color.
|
945
|
+
# The values for _row_ and _column_ are either zero or one.
|
946
|
+
# If the value is zero, returns the background color used for even-numbered
|
947
|
+
# rows (columns). If the value is one, returns the background color used
|
948
|
+
# for odd-numbered rows (columns).
|
949
|
+
# See also #setCellColor.
|
950
|
+
#
|
951
|
+
def getCellColor(row, column) ; end
|
952
|
+
|
953
|
+
# Create a new table item
|
954
|
+
def createItem(text, icon, data) ; end
|
955
|
+
|
956
|
+
# Draw a table cell
|
957
|
+
def drawCell(dc, xlo, xhi, ylo, yhi, xoff, yoff, startRow, endRow, startCol, endCol) ; end
|
958
|
+
|
959
|
+
# Draw a range of cells
|
960
|
+
def drawRange(dc, xlo, xhi, ylo, yhi, xoff, yoff, rlo, rhi, clo, chi) ; end
|
961
|
+
|
962
|
+
# Set column renumbering to +true+ or +false+.
|
963
|
+
def columnRenumbering=(renumber); end
|
964
|
+
|
965
|
+
# Get column renumbering
|
966
|
+
def columnRenumbering? ; end
|
967
|
+
|
968
|
+
# Set row renumbering to +true+ or +false+.
|
969
|
+
def rowRenumbering=(renumber); end
|
970
|
+
|
971
|
+
# Get row renumbering
|
972
|
+
def rowRenumbering? ; end
|
973
|
+
end
|
974
|
+
end
|
975
|
+
|