5#ifndef DCPP_I_GUI_TABLE_HPP_INCLUDED
6#define DCPP_I_GUI_TABLE_HPP_INCLUDED
8#include <duckcpp/core/engine/IGUIElement.hpp>
9#include <duckcpp/core/engine/SColor.hpp>
75 enum EGUI_TABLE_DRAW_FLAGS
Base class of all GUI elements.
Definition IGUIElement.hpp:24
virtual void draw()
Draws the element and its children.
Definition IGUIElement.hpp:331
GUI Environment. Used as factory and manager of all other GUI elements.
Definition IGUIEnvironment.hpp:73
Font interface.
Definition IGUIFont.hpp:40
Default list box GUI element.
Definition IGUITable.hpp:90
virtual IGUIScrollBar * getVerticalScrollBar() const =0
Access the vertical scrollbar.
virtual void swapRows(dcpp::uint32_kt rowIndexA, dcpp::uint32_kt rowIndexB)=0
Swap two row positions.
virtual dcpp::int32_kt getDrawFlags() const =0
Get the flags, as defined in EGUI_TABLE_DRAW_FLAGS, which influence the layout.
virtual IGUIScrollBar * getHorizontalScrollBar() const =0
Access the horizontal scrollbar.
virtual void setCellText(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex, const dcpp::nub::wstring &text, dcpp::video::SColor color)=0
Set the text of a cell, and set a color of this cell.
virtual IGUIFont * getActiveFont() const =0
Get the font which is used right now for drawing.
virtual void setSelected(dcpp::int32_kt index)=0
set which row is currently selected
virtual dcpp::int32_kt getRowCount() const =0
Get amount of rows in the tabcontrol.
virtual void setColumnWidth(dcpp::uint32_kt columnIndex, dcpp::uint32_kt width)=0
Set the width of a column.
virtual void removeRow(dcpp::uint32_kt rowIndex)=0
Remove a row from the table.
virtual void setCellColor(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex, dcpp::video::SColor color)=0
Set the color of a cell text.
virtual dcpp::uint32_kt getColumnWidth(dcpp::uint32_kt columnIndex) const =0
Get the width of a column.
virtual void clear()=0
clears the table, deletes all items in the table
virtual void clearRows()=0
clears the table rows, but keeps the columns intact
virtual dcpp::int32_kt getSelected() const =0
Returns which row is currently selected.
virtual EGUI_ORDERING_MODE getActiveColumnOrdering() const =0
Returns the ordering used by the currently active column.
virtual dcpp::int32_kt getItemHeight() const =0
Get the height of items/rows.
virtual dcpp::uint32_kt addRow(dcpp::uint32_kt rowIndex)=0
adds a row to the table
virtual void setCellData(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex, void *data)=0
Set the data of a cell.
virtual IGUIFont * getOverrideFont(void) const =0
Gets the override font (if any)
virtual void addColumn(const wchar_t *caption, dcpp::int32_kt columnIndex=-1)=0
Adds a column.
virtual void setCellText(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex, const dcpp::nub::wstring &text)=0
Set the text of a cell.
virtual void setDrawBackground(bool draw)=0
Sets whether to draw the background.
virtual void setDrawFlags(dcpp::int32_kt flags)=0
Set flags, as defined in EGUI_TABLE_DRAW_FLAGS, which influence the layout.
IGUITable(IGUIEnvironment *environment, IGUIElement *parent, dcpp::int32_kt id, dcpp::nub::recti rectangle)
constructor
Definition IGUITable.hpp:93
virtual void setColumnOrdering(dcpp::uint32_kt columnIndex, EGUI_COLUMN_ORDERING mode)=0
This tells the table control which ordering mode should be used when a column header is clicked.
virtual void setOverrideFont(IGUIFont *font=0)=0
Sets another skin independent font.
virtual void * getCellData(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex) const =0
Get the data of a cell.
virtual void removeColumn(dcpp::uint32_kt columnIndex)=0
remove a column from the table
virtual bool setActiveColumn(dcpp::int32_kt idx, bool doOrder=false)=0
Makes a column active. This will trigger an ordering process.
virtual const wchar_t * getCellText(dcpp::uint32_kt rowIndex, dcpp::uint32_kt columnIndex) const =0
Get the text of a cell.
virtual void setResizableColumns(bool resizable)=0
columns can be resized by drag 'n drop
virtual bool isDrawBackgroundEnabled() const =0
Checks if background drawing is enabled.
virtual dcpp::int32_kt getActiveColumn() const =0
Returns which header is currently active.
virtual void orderRows(dcpp::int32_kt columnIndex=-1, EGUI_ORDERING_MODE mode=EGOM_NONE)=0
This tells the table to start ordering all the rows.
virtual bool hasResizableColumns() const =0
can columns be resized by drag 'n drop?
virtual dcpp::int32_kt getColumnCount() const =0
Returns the number of columns in the table control.
Rectangle template.
Definition rect.hpp:27
Class representing a 32 bit ARGB color.
Definition SColor.hpp:317
@ EGUIET_TABLE
A Table.
Definition EGUIElementTypes.hpp:77
const dcpp::char_kt *const GUIColumnOrderingNames[]
Names for EGUI_COLUMN_ORDERING types.
Definition IGUITable.hpp:41
EGUI_COLUMN_ORDERING
modes for ordering used when a column header is clicked
Definition IGUITable.hpp:20
@ EGCO_FLIP_ASCENDING_DESCENDING
Sort it ascending on first click, descending on next, etc.
Definition IGUITable.hpp:34
@ EGCO_CUSTOM
Send a EGET_TABLE_HEADER_CHANGED message when a column header is clicked.
Definition IGUITable.hpp:25
@ EGCO_DESCENDING
Sort it descending by it's ascii value like: z,x,y,...
Definition IGUITable.hpp:31
@ EGCO_COUNT
Not used as mode, only to get maximum value for this enum.
Definition IGUITable.hpp:37
@ EGCO_NONE
Do not use ordering.
Definition IGUITable.hpp:22
@ EGCO_ASCENDING
Sort it ascending by it's ascii value like: a,b,c,...
Definition IGUITable.hpp:28
EGUI_ORDERING_MODE
Definition IGUITable.hpp:52
@ EGOM_ASCENDING
Elements are ordered from the smallest to the largest.
Definition IGUITable.hpp:57
@ EGOM_COUNT
Definition IGUITable.hpp:64
@ EGOM_DESCENDING
Elements are ordered from the largest to the smallest.
Definition IGUITable.hpp:60
@ EGOM_NONE
No element ordering.
Definition IGUITable.hpp:54
As of Duckcpp 1.6, position2d is a synonym for vector2d.
Definition shared_device.hpp:34
char char_kt
8 bit character variable.
Definition irrTypes.hpp:37
unsigned int uint32_kt
32 bit unsigned variable.
Definition irrTypes.hpp:64
signed int int32_kt
32 bit signed variable.
Definition irrTypes.hpp:72