Skip to content
Snippets Groups Projects
FXComboBox.i 9.32 KiB
Newer Older
  • Learn to ignore specific revisions
  • /***********************************************************************
     * FXRuby -- the Ruby language bindings for the FOX GUI toolkit.
    
     * Copyright (c) 2001-2009 by Lyle Johnson. All Rights Reserved.
    
     *
     * This library is free software; you can redistribute it and/or
     * modify it under the terms of the GNU Lesser General Public
     * License as published by the Free Software Foundation; either
     * version 2.1 of the License, or (at your option) any later version.
     *
     * This library is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     * Lesser General Public License for more details.
     *
     * You should have received a copy of the GNU Lesser General Public
     * License along with this library; if not, write to the Free Software
     * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
     *
     * For further information please contact the author by e-mail
    
     * at "lyle@lylejohnson.name".
    
     ***********************************************************************/
    
    // ComboBox styles
    enum {
      COMBOBOX_NO_REPLACE     = 0,                  // Leave the list the same
      COMBOBOX_REPLACE        = 0x00020000,         // Replace current item with typed text
      COMBOBOX_INSERT_BEFORE  = 0x00040000,         // Typed text inserted before current
      COMBOBOX_INSERT_AFTER   = 0x00060000,         // Typed text inserted after current
      COMBOBOX_INSERT_FIRST   = 0x00080000,         // Typed text inserted at begin of list
      COMBOBOX_INSERT_LAST    = 0x00090000,         // Typed text inserted at end of list
      COMBOBOX_STATIC         = 0x00100000,         // Unchangable text box
      COMBOBOX_NORMAL         = 0
      };
    
    
    class FXTextField;
    class FXMenuButton;
    class FXList;
    class FXPopup;
    
    %typemap(check) FXint COMBOBOX_ITEM_INDEX {
      if ($1 < 0 || $1 >= arg1->getNumItems()) {
        rb_raise(rb_eIndexError, "combobox item index out of bounds");
      }
    }
    
    %typemap(check) FXint COMBOBOX_ITEM_INDEX_OR_NONE {
      if ($1 < -1 || $1 >= arg1->getNumItems()) {
        rb_raise(rb_eIndexError, "combobox item index out of bounds");
      }
    }
    
    %apply FXint COMBOBOX_ITEM_INDEX { FXint index, FXint newindex, FXint oldindex };
    %apply FXint COMBOBOX_ITEM_INDEX_OR_NONE { FXint indexz };
    
    %rename("justify=") FXComboBox::setJustify(FXuint);
    %rename("justify")  FXComboBox::getJustify() const;
    
    /**
    * A Combo Box provides a way to select a string from a list of strings.
    * Unless COMBOBOX_STATIC is passed, it also allows the user to enter a new
    * string into the text field, for example if the desired entry is not in the
    * list of strings.  Passing COMBOBOX_REPLACE, COMBOBOX_INSERT_BEFORE, COMBOBOX_INSERT_AFTER,
    * COMBOBOX_INSERT_FIRST, or COMBOBOX_INSERT_LAST causes a newly entered text to replace the
    * current one in the list, or be added before or after the current entry, or to be added at
    * the beginning or end of the list.
    * Combo Box is intended to enter text; if you need to enter a choice from a list of
    * options, it is recommended that the List Box widget is used instead.
    * When the text in the field is changed, a SEL_COMMAND will be send to the target.
    * The Combo Box can also receive ID_GETSTRINGVALUE and ID_SETSTRINGVALUE and so
    * on, which will behave similar to Text Field in that they will retrieve or update
    * the value of the field.
    */
    class FXComboBox : public FXPacker {
    protected:
      FXTextField   *field;
      FXMenuButton  *button;
      FXList        *list;
      FXPopup       *pane;
    protected:
      FXComboBox(){}
    public:
      long onFocusUp(FXObject*,FXSelector,void* PTR_EVENT);
      long onFocusDown(FXObject*,FXSelector,void* PTR_EVENT);
      long onFocusSelf(FXObject*,FXSelector,void* PTR_EVENT);
      long onMouseWheel(FXObject*,FXSelector,void* PTR_EVENT);
      long onTextButton(FXObject*,FXSelector,void* PTR_IGNORE);
      long onTextChanged(FXObject*,FXSelector,void* PTR_CSTRING);
      long onTextCommand(FXObject*,FXSelector,void* PTR_CSTRING);
      long onListClicked(FXObject*,FXSelector,void* PTR_INT);
      long onFwdToText(FXObject*,FXSelector,void* PTR_NULL); // FIXME
      long onUpdFmText(FXObject*,FXSelector,void* PTR_IGNORE);
    public:
      enum {
        ID_LIST=FXPacker::ID_LAST,
        ID_TEXT,
        ID_LAST
        };
    public:
      %extend {
        /// Constructor
        FXComboBox(FXComposite *p,FXint cols,FXObject* tgt=NULL,FXSelector sel=0,FXuint opts=COMBOBOX_NORMAL,FXint x=0,FXint y=0,FXint w=0,FXint h=0,FXint pl=DEFAULT_PAD,FXint pr=DEFAULT_PAD,FXint pt=DEFAULT_PAD,FXint pb=DEFAULT_PAD){
          return new FXRbComboBox(p,cols,tgt,sel,opts,x,y,w,h,pl,pr,pt,pb);
          }
        }
    
      /// Return true if combobox is editable
      FXbool isEditable() const;
    
      /// Set editable state
      void setEditable(FXbool edit=TRUE);
    
      /// Set the text
      void setText(const FXString& text);
    
      /// Get the text
      FXString getText() const;
    
      /// Set the number of columns
      void setNumColumns(FXint cols);
    
      /// Get the number of columns
      FXint getNumColumns() const;
    
      /// Change text justification mode; default is JUSTIFY_LEFT
      void setJustify(FXuint mode);
    
      /// Return text justification mode
      FXuint getJustify() const;
    
      /// Return the number of items in the list
      FXint getNumItems() const;
    
      /// Return the number of visible items
      FXint getNumVisible() const;
    
      /// Set the number of visible items
      void setNumVisible(FXint nvis);
    
      /// Return true if current item
      FXbool isItemCurrent(FXint index) const;
    
      /// Set the current item (index is zero-based)
      void setCurrentItem(FXint indexz,FXbool notify=FALSE);
    
      /// Get the current item's index
      FXint getCurrentItem() const;
    
      /// Return the item at the given index
      FXString getItem(FXint index) const;
    
      /// Replace the item at index
      FXint setItem(FXint index,const FXString& text,void* ITEMDATA=NULL);
    
      /// Fill combo box by appending items from array of strings
      FXint fillItems(const FXchar** strings);
    
      /// Insert a new item at index
      FXint insertItem(FXint index,const FXString& text,void* ITEMDATA=NULL);
    
      /// Append an item to the list
      FXint appendItem(const FXString& text,void* ITEMDATA=NULL);
    
      /// Prepend an item to the list
      FXint prependItem(const FXString& text,void* ITEMDATA=NULL);
    
      /// Move item from oldindex to newindex
      FXint moveItem(FXint newindex,FXint oldindex);
    
      /// Remove this item from the list
      void removeItem(FXint index);
    
      /// Remove all items from the list
      void clearItems();
    
      /**
       * Search items by name, beginning from item start.  If the start item
       * is -1 the search will start at the first item in the list.  Flags
       * may be SEARCH_FORWARD or SEARCH_BACKWARD to control the search
       * direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP
       * to control whether the search wraps at the start or end of the list.
       * The option SEARCH_IGNORECASE causes a case-insensitive match.  Finally,
       * passing SEARCH_PREFIX causes searching for a prefix of the item name.
       * Return -1 if no matching item is found.
       */
      FXint findItem(const FXString& text,FXint start=-1,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const;
    
      /**
      * Search items by associated user data, beginning from item start. If the
      * start item is -1 the search will start at the first item in the list.
      * Flags may be SEARCH_FORWARD or SEARCH_BACKWARD to control the
      * search direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP
      * to control whether the search wraps at the start or end of the list.
      * Return -1 if no matching item is found.
      */
      FXint findItemByData(const void *ITEMDATA,FXint start=-1,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const;
    
      /// Set text for specified item
      void setItemText(FXint index,const FXString& text);
    
      /// Get text for specified item
      FXString getItemText(FXint index) const;
    
      %extend {
        /// Set data pointer for specified item
        void setItemData(FXint index, VALUE ptr) {
          self->setItemData(index, (void*) ptr);
          }
    
        /// Get data pointer for specified item
        VALUE getItemData(FXint index) const {
          return self->getItemData(index) ? (VALUE) self->getItemData(index) : Qnil;
          }
      }
    
      /// Is the pane shown
      FXbool isPaneShown() const;
    
      /// Sort items using current sort function
      void sortItems();
    
      /// Set text font
      void setFont(FXFont* fnt);
    
      /// Get text font
      FXFont* getFont() const;
    
      /// Set the combobox style.
      void setComboStyle(FXuint mode);
    
      /// Get the combobox style.
      FXuint getComboStyle() const;
    
      /// Get background color
      FXColor getBackColor() const;
    
      /// Change text color
      void setTextColor(FXColor clr);
    
      /// Return text color
      FXColor getTextColor() const;
    
      /// Change selected background color
      void setSelBackColor(FXColor clr);
    
      /// Return selected background color
      FXColor getSelBackColor() const;
    
      /// Change selected text color
      void setSelTextColor(FXColor clr);
    
      /// Return selected text color
      FXColor getSelTextColor() const;
    
      /// Set the combobox help text
      void setHelpText(const FXString& txt);
    
      /// Get the combobox help text
      const FXString& getHelpText() const;
    
      /// Set the tool tip message for this combobox
      void setTipText(const FXString& txt);
    
      /// Get the tool tip message for this combobox
      const FXString& getTipText() const;
    
      /// Destructor
      virtual ~FXComboBox();
      };
    
    %clear FXint index;
    %clear FXint indexz;
    %clear FXint newindex;
    %clear FXint oldindex;
    
    DECLARE_FXOBJECT_VIRTUALS(FXComboBox)
    DECLARE_FXID_VIRTUALS(FXComboBox)
    DECLARE_FXDRAWABLE_VIRTUALS(FXComboBox)
    DECLARE_FXWINDOW_VIRTUALS(FXComboBox)