Class CTabFolder

  • All Implemented Interfaces:
    Drawable

    public class CTabFolder
    extends Composite
    Instances of this class implement the notebook user interface metaphor. It allows the user to select a notebook page from set of pages.

    The item children that may be added to instances of this class must be of type CTabItem. Control children are created and then set into a tab item using CTabItem#setControl.

    Note that although this class is a subclass of Composite, it does not make sense to set a layout on it.

    Styles:
    CLOSE, TOP, BOTTOM, FLAT, BORDER, SINGLE, MULTI
    Events:
    Selection
    "CTabFolder2"
    Note: Only one of the styles TOP and BOTTOM may be specified.

    IMPORTANT: This class is not intended to be subclassed.

    See Also:
    CTabFolder, CTabItem snippets, SWT Example: CustomControlExample, Sample code and further information
    Restriction:
    This class is not intended to be subclassed by clients.
    • Field Detail

      • marginWidth

        public int marginWidth
        marginWidth specifies the number of points of horizontal margin that will be placed along the left and right edges of the form. The default value is 0.
      • marginHeight

        public int marginHeight
        marginHeight specifies the number of points of vertical margin that will be placed along the top and bottom edges of the form. The default value is 0.
      • MIN_TAB_WIDTH

        @Deprecated
        public int MIN_TAB_WIDTH
        Deprecated.
        This field is no longer used. See setMinimumCharacters(int)
        A multiple of the tab height that specifies the minimum width to which a tab will be compressed before scrolling arrows are used to navigate the tabs. NOTE This field is badly named and can not be fixed for backwards compatibility. It should not be capitalized.
      • borderInsideRGB

        @Deprecated
        public static RGB borderInsideRGB
        Deprecated.
        drop shadow border is no longer drawn in 3.0
        Color of innermost line of drop shadow border. NOTE This field is badly named and can not be fixed for backwards compatibility. It should be capitalized.
      • borderMiddleRGB

        @Deprecated
        public static RGB borderMiddleRGB
        Deprecated.
        drop shadow border is no longer drawn in 3.0
        Color of middle line of drop shadow border. NOTE This field is badly named and can not be fixed for backwards compatibility. It should be capitalized.
      • borderOutsideRGB

        @Deprecated
        public static RGB borderOutsideRGB
        Deprecated.
        drop shadow border is no longer drawn in 3.0
        Color of outermost line of drop shadow border. NOTE This field is badly named and can not be fixed for backwards compatibility. It should be capitalized.
    • Constructor Detail

      • CTabFolder

        public CTabFolder​(Composite parent,
                          int style)
        Constructs a new instance of this class given its parent and a style value describing its behavior and appearance.

        The style value is either one of the style constants defined in class SWT which is applicable to instances of this class, or must be built by bitwise OR'ing together (that is, using the int "|" operator) two or more of those SWT style constants. The class description lists the style constants that are applicable to the class. Style bits are also inherited from superclasses.

        Parameters:
        parent - a widget which will be the parent of the new instance (cannot be null)
        style - the style of widget to construct
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the parent is null
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the parent
        See Also:
        SWT.TOP, SWT.BOTTOM, SWT.FLAT, SWT.BORDER, SWT.SINGLE, SWT.MULTI, getStyle()
    • Method Detail

      • addCTabFolder2Listener

        public void addCTabFolder2Listener​(CTabFolder2Listener listener)
        Adds the listener to the collection of listeners who will be notified when a tab item is closed, minimized, maximized, restored, or to show the list of items that are not currently visible.
        Parameters:
        listener - the listener which should be notified
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the listener is null
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.0
        See Also:
        CTabFolder2Listener, removeCTabFolder2Listener(CTabFolder2Listener)
      • addSelectionListener

        public void addSelectionListener​(SelectionListener listener)
        Adds the listener to the collection of listeners who will be notified when the user changes the receiver's selection, by sending it one of the messages defined in the SelectionListener interface.

        widgetSelected is called when the user changes the selected tab. widgetDefaultSelected is not called.

        Parameters:
        listener - the listener which should be notified when the user changes the receiver's selection
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the listener is null
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        See Also:
        SelectionListener, removeSelectionListener(org.eclipse.swt.events.SelectionListener), SelectionEvent
      • computeTrim

        public Rectangle computeTrim​(int x,
                                     int y,
                                     int width,
                                     int height)
        Description copied from class: Scrollable
        Given a desired client area for the receiver (as described by the arguments), returns the bounding rectangle which would be required to produce that client area.

        In other words, it returns a rectangle such that, if the receiver's bounds were set to that rectangle, the area of the receiver which is capable of displaying data (that is, not covered by the "trimmings") would be the rectangle described by the arguments (relative to the receiver's parent).

        Overrides:
        computeTrim in class Scrollable
        Parameters:
        x - the desired x coordinate of the client area
        y - the desired y coordinate of the client area
        width - the desired width of the client area
        height - the desired height of the client area
        Returns:
        the required bounds to produce the given client area
        See Also:
        Scrollable.getClientArea()
      • getBorderVisible

        public boolean getBorderVisible()
        Returns true if the receiver's border is visible.
        Returns:
        the receiver's border visibility state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getItem

        public CTabItem getItem​(int index)
        Return the tab that is located at the specified index.
        Parameters:
        index - the index of the tab item
        Returns:
        the item at the specified index
        Throws:
        IllegalArgumentException -
        • ERROR_INVALID_RANGE - if the index is out of range
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getItem

        public CTabItem getItem​(Point pt)
        Gets the item at a point in the widget.
        Parameters:
        pt - the point in coordinates relative to the CTabFolder
        Returns:
        the item at a point or null
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getItemCount

        public int getItemCount()
        Return the number of tabs in the folder.
        Returns:
        the number of tabs in the folder
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getItems

        public CTabItem[] getItems()
        Return the tab items.
        Returns:
        the tab items
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getMinimized

        public boolean getMinimized()
        Returns true if the receiver is minimized.
        Returns:
        the receiver's minimized state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getMinimizeVisible

        public boolean getMinimizeVisible()
        Returns true if the minimize button is visible.
        Returns:
        the visibility of the minimized button
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getMinimumCharacters

        public int getMinimumCharacters()
        Returns the number of characters that will appear in a fully compressed tab.
        Returns:
        number of characters that will appear in a fully compressed tab
        Since:
        3.0
      • getMaximized

        public boolean getMaximized()
        Returns true if the receiver is maximized.

        Returns:
        the receiver's maximized state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getMaximizeVisible

        public boolean getMaximizeVisible()
        Returns true if the maximize button is visible.
        Returns:
        the visibility of the maximized button
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getMRUVisible

        public boolean getMRUVisible()
        Returns true if the receiver displays most recently used tabs and false otherwise.

        When there is not enough horizontal space to show all the tabs, by default, tabs are shown sequentially from left to right in order of their index. When the MRU visibility is turned on, the tabs that are visible will be the tabs most recently selected. Tabs will still maintain their left to right order based on index but only the most recently selected tabs are visible.

        For example, consider a CTabFolder that contains "Tab 1", "Tab 2", "Tab 3" and "Tab 4" (in order by index). The user selects "Tab 1" and then "Tab 3". If the CTabFolder is now compressed so that only two tabs are visible, by default, "Tab 2" and "Tab 3" will be shown ("Tab 3" since it is currently selected and "Tab 2" because it is the previous item in index order). If MRU visibility is enabled, the two visible tabs will be "Tab 1" and "Tab 3" (in that order from left to right).

        Returns:
        the receiver's header's visibility state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.1
      • getSelection

        public CTabItem getSelection()
        Return the selected tab item, or null if there is no selection.
        Returns:
        the selected tab item, or null if none has been selected
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getSelectionBackground

        public Color getSelectionBackground()
        Returns the receiver's selection background color.
        Returns:
        the selection background color of the receiver
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getSelectionForeground

        public Color getSelectionForeground()
        Returns the receiver's selection foreground color.
        Returns:
        the selection foreground color of the receiver
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • getSelectionIndex

        public int getSelectionIndex()
        Return the index of the selected tab item, or -1 if there is no selection.
        Returns:
        the index of the selected tab item or -1
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getSimple

        public boolean getSimple()
        Returns true if the CTabFolder is rendered with a simple, traditional shape.
        Returns:
        true if the CTabFolder is rendered with a simple shape
        Since:
        3.0
      • getSingle

        public boolean getSingle()
        Returns true if the CTabFolder only displays the selected tab and false if the CTabFolder displays multiple tabs.
        Returns:
        true if the CTabFolder only displays the selected tab and false if the CTabFolder displays multiple tabs
        Since:
        3.0
      • getStyle

        public int getStyle()
        Description copied from class: Widget
        Returns the receiver's style information.

        Note that the value which is returned by this method may not match the value which was provided to the constructor when the receiver was created. This can occur when the underlying operating system does not support a particular combination of requested styles. For example, if the platform widget used to implement a particular SWT widget always has scroll bars, the result of calling this method would always have the SWT.H_SCROLL and SWT.V_SCROLL bits set.

        Overrides:
        getStyle in class Widget
        Returns:
        the style bits
      • getTabHeight

        public int getTabHeight()
        Returns the height of the tab
        Returns:
        the height of the tab
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getTabPosition

        public int getTabPosition()
        Returns the position of the tab. Possible values are SWT.TOP or SWT.BOTTOM.
        Returns:
        the position of the tab
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • getTopRight

        public Control getTopRight()
        Returns the control in the top right corner of the tab folder. Typically this is a close button or a composite with a menu and close button.
        Returns:
        the control in the top right corner of the tab folder or null
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        2.1
      • getTopRightAlignment

        public int getTopRightAlignment()
        Returns the alignment of the top right control.
        Returns:
        the alignment of the top right control which is either SWT.RIGHT or SWT.FILL
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.6
      • getUnselectedCloseVisible

        public boolean getUnselectedCloseVisible()
        Returns true if the close button appears when the user hovers over an unselected tabs.
        Returns:
        true if the close button appears on unselected tabs
        Since:
        3.0
      • getUnselectedImageVisible

        public boolean getUnselectedImageVisible()
        Returns true if an image appears in unselected tabs.
        Returns:
        true if an image appears in unselected tabs
        Since:
        3.0
      • indexOf

        public int indexOf​(CTabItem item)
        Return the index of the specified tab or -1 if the tab is not in the receiver.
        Parameters:
        item - the tab item for which the index is required
        Returns:
        the index of the specified tab item or -1
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the listener is null
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • removeCTabFolderListener

        @Deprecated
        public void removeCTabFolderListener​(CTabFolderListener listener)
        Deprecated.
        see removeCTabFolderCloseListener(CTabFolderListener)
        Removes the listener.
        Parameters:
        listener - the listener which should no longer be notified
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the listener is null
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • reskin

        public void reskin​(int flags)
        Description copied from class: Widget
        Marks the widget to be skinned.

        The skin event is sent to the receiver's display when appropriate (usually before the next event is handled). Widgets are automatically marked for skinning upon creation as well as when its skin id or class changes. The skin id and/or class can be changed by calling Display.setData(String, Object) with the keys SWT.SKIN_ID and/or SWT.SKIN_CLASS. Once the skin event is sent to a widget, it will not be sent again unless reskin(int) is called on the widget or on an ancestor while specifying the SWT.ALL flag.

        The parameter flags may be either:

        SWT.ALL
        all children in the receiver's widget tree should be skinned
        SWT.NONE
        only the receiver should be skinned
        Overrides:
        reskin in class Widget
        Parameters:
        flags - the flags specifying how to reskin
      • setBackground

        public void setBackground​(Color color)
        Description copied from class: Control
        Sets the receiver's background color to the color specified by the argument, or to the default system color for the control if the argument is null.

        Note: This operation is a hint and may be overridden by the platform.

        Overrides:
        setBackground in class Control
        Parameters:
        color - the new color (or null)
      • setBackground

        public void setBackground​(Color[] colors,
                                  int[] percents)
        Specify a gradient of colors to be drawn in the background of the unselected tabs. For example to draw a gradient that varies from dark blue to blue and then to white, use the following call to setBackground:
                cfolder.setBackground(new Color[]{display.getSystemColor(SWT.COLOR_DARK_BLUE),
                                                   display.getSystemColor(SWT.COLOR_BLUE),
                                                   display.getSystemColor(SWT.COLOR_WHITE),
                                                   display.getSystemColor(SWT.COLOR_WHITE)},
                                       new int[] {25, 50, 100});
         
        Parameters:
        colors - an array of Color that specifies the colors to appear in the gradient in order of appearance left to right. The value null clears the background gradient. The value null can be used inside the array of Color to specify the background color.
        percents - an array of integers between 0 and 100 specifying the percent of the width of the widget at which the color should change. The size of the percents array must be one less than the size of the colors array.
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.6
      • setBackground

        public void setBackground​(Color[] colors,
                                  int[] percents,
                                  boolean vertical)
        Specify a gradient of colors to be drawn in the background of the unselected tab. For example to draw a vertical gradient that varies from dark blue to blue and then to white, use the following call to setBackground:
                cfolder.setBackground(new Color[]{display.getSystemColor(SWT.COLOR_DARK_BLUE),
                                                   display.getSystemColor(SWT.COLOR_BLUE),
                                                   display.getSystemColor(SWT.COLOR_WHITE),
                                                   display.getSystemColor(SWT.COLOR_WHITE)},
                                          new int[] {25, 50, 100}, true);
         
        Parameters:
        colors - an array of Color that specifies the colors to appear in the gradient in order of appearance left to right. The value null clears the background gradient. The value null can be used inside the array of Color to specify the background color.
        percents - an array of integers between 0 and 100 specifying the percent of the width of the widget at which the color should change. The size of the percents array must be one less than the size of the colors array.
        vertical - indicate the direction of the gradient. True is vertical and false is horizontal.
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.6
      • setBackgroundImage

        public void setBackgroundImage​(Image image)
        Description copied from class: Control
        Sets the receiver's background image to the image specified by the argument, or to the default system color for the control if the argument is null. The background image is tiled to fill the available space.

        Note: This operation is a hint and may be overridden by the platform. For example, on Windows the background of a Button cannot be changed.

        Overrides:
        setBackgroundImage in class Control
        Parameters:
        image - the new image (or null)
      • setBorderVisible

        public void setBorderVisible​(boolean show)
        Toggle the visibility of the border
        Parameters:
        show - true if the border should be displayed
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setFocus

        public boolean setFocus()
        Description copied from class: Control
        Causes the receiver to have the keyboard focus, such that all keyboard events will be delivered to it. Focus reassignment will respect applicable platform constraints.
        Overrides:
        setFocus in class Composite
        Returns:
        true if the control got focus, and false if it was unable to.
        See Also:
        Control.forceFocus()
      • setFont

        public void setFont​(Font font)
        Description copied from class: Control
        Sets the font that the receiver will use to paint textual information to the font specified by the argument, or to the default font for that kind of control if the argument is null.
        Overrides:
        setFont in class Control
        Parameters:
        font - the new font (or null)
      • setForeground

        public void setForeground​(Color color)
        Description copied from class: Control
        Sets the receiver's foreground color to the color specified by the argument, or to the default system color for the control if the argument is null.

        Note: This operation is a hint and may be overridden by the platform.

        Overrides:
        setForeground in class Control
        Parameters:
        color - the new color (or null)
      • setInsertMark

        public void setInsertMark​(CTabItem item,
                                  boolean after)
        Display an insert marker before or after the specified tab item. A value of null will clear the mark.
        Parameters:
        item - the item with which the mark is associated or null
        after - true if the mark should be displayed after the specified item
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setInsertMark

        public void setInsertMark​(int index,
                                  boolean after)
        Display an insert marker before or after the specified tab item. A value of -1 will clear the mark.
        Parameters:
        index - the index of the item with which the mark is associated or -1
        after - true if the mark should be displayed after the specified item
        Throws:
        IllegalArgumentException -
        • ERROR_INVALID_ARGUMENT when the index is invalid
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setMaximizeVisible

        public void setMaximizeVisible​(boolean visible)
        Marks the receiver's maximize button as visible if the argument is true, and marks it invisible otherwise.
        Parameters:
        visible - the new visibility state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setLayout

        public void setLayout​(Layout layout)
        Sets the layout which is associated with the receiver to be the argument which may be null.

        Note: No Layout can be set on this Control because it already manages the size and position of its children.

        Overrides:
        setLayout in class Composite
        Parameters:
        layout - the receiver's new layout or null
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setMaximized

        public void setMaximized​(boolean maximize)
        Sets the maximized state of the receiver.
        Parameters:
        maximize - the new maximized state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setMinimizeVisible

        public void setMinimizeVisible​(boolean visible)
        Marks the receiver's minimize button as visible if the argument is true, and marks it invisible otherwise.
        Parameters:
        visible - the new visibility state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setMinimized

        public void setMinimized​(boolean minimize)
        Sets the minimized state of the receiver.
        Parameters:
        minimize - the new minimized state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setMinimumCharacters

        public void setMinimumCharacters​(int count)
        Sets the minimum number of characters that will be displayed in a fully compressed tab.
        Parameters:
        count - the minimum number of characters that will be displayed in a fully compressed tab
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        • ERROR_INVALID_RANGE - if the count is less than zero
        Since:
        3.0
      • setMRUVisible

        public void setMRUVisible​(boolean show)
        When there is not enough horizontal space to show all the tabs, by default, tabs are shown sequentially from left to right in order of their index. When the MRU visibility is turned on, the tabs that are visible will be the tabs most recently selected. Tabs will still maintain their left to right order based on index but only the most recently selected tabs are visible.

        For example, consider a CTabFolder that contains "Tab 1", "Tab 2", "Tab 3" and "Tab 4" (in order by index). The user selects "Tab 1" and then "Tab 3". If the CTabFolder is now compressed so that only two tabs are visible, by default, "Tab 2" and "Tab 3" will be shown ("Tab 3" since it is currently selected and "Tab 2" because it is the previous item in index order). If MRU visibility is enabled, the two visible tabs will be "Tab 1" and "Tab 3" (in that order from left to right).

        Parameters:
        show - the new visibility state
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.1
      • setRenderer

        public void setRenderer​(CTabFolderRenderer renderer)
        Sets the renderer which is associated with the receiver to be the argument which may be null. In the case of null, the default renderer is used.
        Parameters:
        renderer - a new renderer
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.6
        See Also:
        CTabFolderRenderer
      • setSelection

        public void setSelection​(CTabItem item)
        Set the selection to the tab at the specified item.
        Parameters:
        item - the tab item to be selected
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the item is null
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • setSelection

        public void setSelection​(int index)
        Set the selection to the tab at the specified index.
        Parameters:
        index - the index of the tab item to be selected
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setSelectionBackground

        public void setSelectionBackground​(Color color)
        Sets the receiver's selection background color to the color specified by the argument, or to the default system color for the control if the argument is null.
        Parameters:
        color - the new color (or null)
        Throws:
        IllegalArgumentException -
        • ERROR_INVALID_ARGUMENT - if the argument has been disposed
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setSelectionBackground

        public void setSelectionBackground​(Color[] colors,
                                           int[] percents)
        Specify a gradient of colours to be draw in the background of the selected tab. For example to draw a gradient that varies from dark blue to blue and then to white, use the following call to setBackground:
                cfolder.setBackground(new Color[]{display.getSystemColor(SWT.COLOR_DARK_BLUE),
                                                   display.getSystemColor(SWT.COLOR_BLUE),
                                                   display.getSystemColor(SWT.COLOR_WHITE),
                                                   display.getSystemColor(SWT.COLOR_WHITE)},
                                       new int[] {25, 50, 100});
         
        Parameters:
        colors - an array of Color that specifies the colors to appear in the gradient in order of appearance left to right. The value null clears the background gradient. The value null can be used inside the array of Color to specify the background color.
        percents - an array of integers between 0 and 100 specifying the percent of the width of the widget at which the color should change. The size of the percents array must be one less than the size of the colors array.
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
      • setSelectionBackground

        public void setSelectionBackground​(Color[] colors,
                                           int[] percents,
                                           boolean vertical)
        Specify a gradient of colours to be draw in the background of the selected tab. For example to draw a vertical gradient that varies from dark blue to blue and then to white, use the following call to setBackground:
                cfolder.setBackground(new Color[]{display.getSystemColor(SWT.COLOR_DARK_BLUE),
                                                   display.getSystemColor(SWT.COLOR_BLUE),
                                                   display.getSystemColor(SWT.COLOR_WHITE),
                                                   display.getSystemColor(SWT.COLOR_WHITE)},
                                          new int[] {25, 50, 100}, true);
         
        Parameters:
        colors - an array of Color that specifies the colors to appear in the gradient in order of appearance left to right. The value null clears the background gradient. The value null can be used inside the array of Color to specify the background color.
        percents - an array of integers between 0 and 100 specifying the percent of the width of the widget at which the color should change. The size of the percents array must be one less than the size of the colors array.
        vertical - indicate the direction of the gradient. True is vertical and false is horizontal.
        Throws:
        SWTException -
        • ERROR_THREAD_INVALID_ACCESS when called from the wrong thread
        • ERROR_WIDGET_DISPOSED when the widget has been disposed
        Since:
        3.0
      • setSelectionBackground

        public void setSelectionBackground​(Image image)
        Set the image to be drawn in the background of the selected tab. Image is stretched or compressed to cover entire selection tab area.
        Parameters:
        image - the image to be drawn in the background
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setSelectionForeground

        public void setSelectionForeground​(Color color)
        Set the foreground color of the selected tab.
        Parameters:
        color - the color of the text displayed in the selected tab
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
      • setSimple

        public void setSimple​(boolean simple)
        Sets the shape that the CTabFolder will use to render itself.
        Parameters:
        simple - true if the CTabFolder should render itself in a simple, traditional style
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setSingle

        public void setSingle​(boolean single)
        Sets the number of tabs that the CTabFolder should display
        Parameters:
        single - true if only the selected tab should be displayed otherwise, multiple tabs will be shown.
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setTabHeight

        public void setTabHeight​(int height)
        Specify a fixed height for the tab items. If no height is specified, the default height is the height of the text or the image, whichever is greater. Specifying a height of -1 will revert to the default height.
        Parameters:
        height - the point value of the height or -1
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        • ERROR_INVALID_ARGUMENT - if called with a height of less than 0
      • setTabPosition

        public void setTabPosition​(int position)
        Specify whether the tabs should appear along the top of the folder or along the bottom of the folder.
        Parameters:
        position - SWT.TOP for tabs along the top or SWT.BOTTOM for tabs along the bottom
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        • ERROR_INVALID_ARGUMENT - if the position value is not either SWT.TOP or SWT.BOTTOM
        Since:
        3.0
      • setTopRight

        public void setTopRight​(Control control)
        Set the control that appears in the top right corner of the tab folder. Typically this is a close button or a composite with a Menu and close button. The topRight control is optional. Setting the top right control to null will remove it from the tab folder.
        Parameters:
        control - the control to be displayed in the top right corner or null
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        • ERROR_INVALID_ARGUMENT - if the control is disposed, or not a child of this CTabFolder
        Since:
        2.1
      • setTopRight

        public void setTopRight​(Control control,
                                int alignment)
        Set the control that appears in the top right corner of the tab folder. Typically this is a close button or a composite with a Menu and close button. The topRight control is optional. Setting the top right control to null will remove it from the tab folder.

        The alignment parameter sets the layout of the control in the tab area. SWT.RIGHT will cause the control to be positioned on the far right of the folder and it will have its default size. SWT.FILL will size the control to fill all the available space to the right of the last tab. If there is no available space, the control will not be visible. SWT.RIGHT | SWT.WRAP will allow the control to wrap below the tabs if there is not enough available space to the right of the last tab.

        Parameters:
        control - the control to be displayed in the top right corner or null
        alignment - SWT.RIGHT or SWT.FILL or SWT.RIGHT | SWT.WRAP
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        • ERROR_INVALID_ARGUMENT - if the control is disposed, or not a child of this CTabFolder
        Since:
        3.0
      • setUnselectedCloseVisible

        public void setUnselectedCloseVisible​(boolean visible)
        Specify whether the close button appears when the user hovers over an unselected tabs.
        Parameters:
        visible - true makes the close button appear
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • setUnselectedImageVisible

        public void setUnselectedImageVisible​(boolean visible)
        Specify whether the image appears on unselected tabs.
        Parameters:
        visible - true makes the image appear
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.0
      • showItem

        public void showItem​(CTabItem item)
        Shows the item. If the item is already showing in the receiver, this method simply returns. Otherwise, the items are scrolled until the item is visible.
        Parameters:
        item - the item to be shown
        Throws:
        IllegalArgumentException -
        • ERROR_NULL_ARGUMENT - if the item is null
        • ERROR_INVALID_ARGUMENT - if the item has been disposed
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        2.0
        See Also:
        showSelection()
      • showSelection

        public void showSelection()
        Shows the selection. If the selection is already showing in the receiver, this method simply returns. Otherwise, the items are scrolled until the selection is visible.
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        2.0
        See Also:
        showItem(CTabItem)
      • setHighlightEnabled

        public void setHighlightEnabled​(boolean enabled)
        Sets whether the selected tab is rendered as highlighted.
        Parameters:
        enabled - true if the selected tab should be highlighted, false otherwise.
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.106
      • getHighlightEnabled

        public boolean getHighlightEnabled()
        Returns true if the selected tab is rendered as highlighted.
        Returns:
        true if the selected tab is rendered as highlighted
        Throws:
        SWTException -
        • ERROR_WIDGET_DISPOSED - if the receiver has been disposed
        • ERROR_THREAD_INVALID_ACCESS - if not called from the thread that created the receiver
        Since:
        3.106