Pyro higlevel API
Classes | Public Types | Public Member Functions | Friends | List of all members
os::ListView Class Reference

Flexible multicolumn list view. More...

Inheritance diagram for os::ListView:
os::Control os::View os::Invoker os::Handler os::DirectoryView os::TreeView

Classes

class  Private
 

Public Types

enum  scroll_direction {
  SCROLL_UP,
  SCROLL_DOWN
}
 
enum  { AUTOSCROLL_BORDER = 20 }
 
enum  {
  F_MULTI_SELECT = 0x0001,
  F_NO_AUTO_SORT = 0x0002,
  F_RENDER_BORDER = 0x0004,
  F_DONT_SCROLL = 0x0008,
  F_NO_HEADER = 0x0010,
  F_NO_COL_REMAP = 0x0020,
  F_NO_SORT = 0x0040
}
 
enum  {
  INV_HEIGHT = 0x01,
  INV_WIDTH = 0x02,
  INV_VISUAL = 0x04
}
 
typedef std::vector
< ListViewRow * >
::const_iterator 
const_iterator
 
typedef std::vector< int > column_map
 

Public Member Functions

 ListView (const Rect &cFrame, const String &cTitle, uint32 nModeFlags=F_MULTI_SELECT|F_RENDER_BORDER, uint32 nResizeMask=CF_FOLLOW_LEFT|CF_FOLLOW_TOP, uint32 nFlags=WID_WILL_DRAW|WID_FULL_UPDATE_ON_RESIZE)
 
 ~ListView ()
 
virtual void LabelChanged (const String &cNewLabel)
 
virtual void EnableStatusChanged (bool bIsEnabled)
 
virtual bool Invoked (Message *pcMessage)
 Intercept outgoing messages. More...
 
virtual void Invoked (int nFirstRow, int nLastRow)
 
virtual void SelectionChanged (int nFirstRow, int nLastRow)
 
virtual bool DragSelection (const Point &cPos)
 
void StartScroll (scroll_direction eDirection, bool bSelect)
 
void StopScroll ()
 
bool IsMultiSelect () const
 
void SetMultiSelect (bool bMulti)
 
bool IsAutoSort () const
 
void SetAutoSort (bool bAuto)
 
bool HasBorder () const
 
void SetRenderBorder (bool bRender)
 
bool HasColumnHeader () const
 
void SetHasColumnHeader (bool bFlag)
 Turn column header on or off. More...
 
void MakeVisible (int nRow, bool bCenter=true)
 Make row visible. More...
 
int InsertColumn (const char *pzTitle, int nWidth, int nPos=-1)
 
const column_mapGetColumnMapping () const
 
void SetColumnMapping (const column_map &cMap)
 
void InsertRow (int nPos, ListViewRow *pcRow, bool bUpdate=true)
 Insert a row. More...
 
void InsertRow (ListViewRow *pcRow, bool bUpdate=true)
 Insert a row. More...
 
ListViewRowRemoveRow (int nIndex, bool bUpdate=true)
 Remove a row. More...
 
void InvalidateRow (int nRow, uint32 nFlags)
 Refresh row. More...
 
uint GetRowCount () const
 Get row count. More...
 
ListViewRowGetRow (const Point &cPos) const
 Find row at a certain position. More...
 
ListViewRowGetRow (uint nIndex) const
 Get a row. More...
 
int HitTest (const Point &cPos) const
 Find row at a certain position. More...
 
float GetRowPos (int nRow)
 Get row vertical position. More...
 
void Clear ()
 Clear list. More...
 
bool IsSelected (uint nRow) const
 Check if a row is selected. More...
 
void Select (int nFirst, int nLast, bool bReplace=true, bool bSelect=true)
 
void Select (int nRow, bool bReplace=true, bool bSelect=true)
 
void ClearSelection ()
 
void Highlight (int nFirst, int nLast, bool bReplace, bool bHighlight=true)
 
void Highlight (int nRow, bool bReplace, bool bHighlight=true)
 
void SetCurrentRow (int nRow)
 
void Sort ()
 Sort rows. More...
 
int GetFirstSelected () const
 Get first selected row. More...
 
int GetLastSelected () const
 
void SetSelChangeMsg (Message *pcMsg)
 
void SetInvokeMsg (Message *pcMsg)
 
MessageGetSelChangeMsg () const
 
MessageGetInvokeMsg () const
 
virtual void Paint (const Rect &cUpdateRect)
 Called by the system update "damaged" areas of the view. More...
 
virtual void FrameSized (const Point &cDelta)
 Virtual hook called by the system when the view is resized. More...
 
virtual void KeyDown (const char *pzString, const char *pzRawString, uint32 nQualifiers)
 Hook called by the system when a key is pressed while the view has focus. More...
 
virtual void AllAttached ()
 
virtual bool HasFocus (void) const
 
virtual void SortRows (std::vector< ListViewRow * > *pcRows, int nColumn)
 Sort rows. More...
 
virtual void MouseDown (const Point &, uint32)
 Hook called by the system when a mouse button is pressed. More...
 
virtual void MouseUp (const Point &cPosition, uint32 nButton, Message *pcData)
 Hook called by the system when a mouse button is release. More...
 
virtual void MouseMove (const Point &cNewPos, int nCode, uint32 nButtons, Message *pcData)
 Hook called by the system when the mouse is moved. More...
 
const_iterator begin () const
 STL iterator interface. More...
 
const_iterator end () const
 STL iterator interface. More...
 
void RefreshLayout ()
 Refresh layout. More...
 
- Public Member Functions inherited from os::Control
 Control (const Rect &cFrame, const String &cName, const String &cLabel, Message *pcMessage, uint32 nResizeMask, uint32 nFlags=WID_WILL_DRAW|WID_CLEAR_BACKGROUND)
 
 ~Control ()
 
virtual void AttachedToWindow (void)
 
virtual void DetachedFromWindow (void)
 
virtual bool PreValueChange (Variant *pcNewValue)
 
virtual void PostValueChange (const Variant &cNewValue)
 
virtual void SetEnable (bool bEnabled)
 
virtual bool IsEnabled (void) const
 
virtual void SetLabel (const String &cLabel)
 
virtual String GetLabel (void) const
 
virtual void SetValue (Variant cValue, bool bInvoke=true)
 
virtual Variant GetValue () const
 
virtual void __CTRL_reserved1__ ()
 
virtual void __CTRL_reserved2__ ()
 
virtual void __CTRL_reserved3__ ()
 
virtual void __CTRL_reserved4__ ()
 
virtual void __CTRL_reserved5__ ()
 
- Public Member Functions inherited from os::View
 View (const Rect &cFrame, const String &cTitle, uint32 nResizeMask=CF_FOLLOW_LEFT|CF_FOLLOW_TOP, uint32 nFlags=WID_WILL_DRAW|WID_CLEAR_BACKGROUND)
 View constructor. More...
 
virtual ~View ()
 View destructor. More...
 
virtual void AllDetached ()
 
virtual void Activated (bool bIsActive)
 Hook called when the view gain or loose focus. More...
 
virtual void WindowActivated (bool bIsActive)
 Hook called when the window hosting this view gain or loose focus. More...
 
virtual void KeyUp (const char *pzString, const char *pzRawString, uint32 nQualifiers)
 Hook called by the system when a key is released while the view has focus. More...
 
virtual void FrameMoved (const Point &cDelta)
 Virtual hook called by the system when the view is moved within it's parent. More...
 
virtual void ViewScrolled (const Point &cDelta)
 Virtual hook called by the system when the view content is scrolled. More...
 
virtual void FontChanged (Font *pcNewFont)
 Called to notify the view that the font has changed. More...
 
virtual Point GetPreferredSize (bool bLargest) const
 
virtual Point GetContentSize () const
 
virtual void WheelMoved (const Point &cDelta)
 Hook called by the system when the scroll-wheel is rotated. More...
 
virtual void AddChild (View *pcView, bool bAssignTabOrder=false)
 
void RemoveChild (View *pcChild)
 
void RemoveThis ()
 
ViewGetChildAt (const Point &cPos) const
 
ViewGetChildAt (int nIndex) const
 
ViewGetParent () const
 
ScrollBarGetVScrollBar () const
 
ScrollBarGetHScrollBar () const
 
WindowGetWindow () const
 
String GetTitle () const
 
virtual int GetTabOrder () const
 Get the keybord manouvering order. More...
 
virtual void SetTabOrder (int nOrder=NEXT_TAB_ORDER)
 Set the keyboard manouvering sorting order. More...
 
virtual const ShortcutKeyGetShortcut () const
 
virtual void SetShortcut (const ShortcutKey &cShortcut)
 Set keyboard shortcut. More...
 
virtual void SetShortcutFromLabel (const String &cLabel)
 Set keyboard shortcut from Label. More...
 
void SetContextMenu (Menu *pcMenu)
 Set popup menu for a View. More...
 
MenuGetContextMenu () const
 Get popup menu. More...
 
uint32 GetQualifiers () const
 
void GetMouse (Point *pcPosition, uint32 *pnButtons) const
 
void SetMousePos (const Point &cPosition)
 
void BeginDrag (Message *pcData, const Point &cOffset, const Bitmap *pcBitmap, Handler *pcReplyTarget=NULL)
 Start a drag and drop operation. More...
 
void BeginDrag (Message *pcData, const Point &cOffset, const Rect &cBounds, Handler *pcReplyTarget=NULL)
 Start a drag and drop operation. More...
 
void SetFlags (uint32 nFlags)
 
uint32 GetFlags (uint32 nMask=~0L) const
 
void SetResizeMask (uint32 nFlags)
 
uint32 GetResizeMask () const
 
void Show (bool bVisible=true)
 Show/hide a view and all it's children. More...
 
void Hide ()
 
bool IsVisible () const
 
virtual void MakeFocus (bool bFocus=true)
 
Rect GetFrame () const
 
Rect GetBounds () const
 
Rect GetNormalizedBounds () const
 
float Width () const
 
float Height () const
 
Point GetLeftTop () const
 
virtual void SetFrame (const Rect &cRect, bool bNotifyServer=true)
 Set the size and position relative to the parent view. More...
 
virtual void MoveBy (const Point &cDelta)
 Move the view within the parent coordinate system. More...
 
virtual void MoveBy (float vDeltaX, float vDeltaY)
 
virtual void MoveTo (const Point &cPos)
 Set the views position within the parent coordinate system. More...
 
virtual void MoveTo (float x, float y)
 
virtual void ResizeBy (const Point &cDelta)
 
virtual void ResizeBy (float vDeltaW, float vDeltaH)
 
virtual void ResizeTo (const Point &cSize)
 Set a new absolute size for the view. More...
 
virtual void ResizeTo (float W, float H)
 Set a new absolute size for the view. More...
 
void SetDrawingRegion (const Region &cReg)
 Restrict rendering using a clipping region. More...
 
void ClearDrawingRegion ()
 Remove any previously assigned drawing region. More...
 
void SetShapeRegion (const Region &cReg)
 Define a non-square shape for the view. More...
 
void ClearShapeRegion ()
 Remove any previously assigned shape region. More...
 
virtual int ToggleDepth ()
 
Point ConvertFromParent (const Point &cPoint) const
 
void ConvertFromParent (Point *cPoint) const
 
Rect ConvertFromParent (const Rect &cRect) const
 
void ConvertFromParent (Rect *cRect) const
 
Point ConvertToWindow (const Point &cPoint) const
 
void ConvertToWindow (Point *cPoint) const
 
Rect ConvertToWindow (const Rect &cRect) const
 
void ConvertToWindow (Rect *cRect) const
 
Point ConvertFromWindow (const Point &cPoint) const
 
void ConvertFromWindow (Point *cPoint) const
 
Rect ConvertFromWindow (const Rect &cRect) const
 
void ConvertFromWindow (Rect *cRect) const
 
Point ConvertToScreen (const Point &cPoint) const
 
void ConvertToScreen (Point *cPoint) const
 
Rect ConvertToScreen (const Rect &cRect) const
 
void ConvertToScreen (Rect *cRect) const
 
Point ConvertFromScreen (const Point &cPoint) const
 
void ConvertFromScreen (Point *cPoint) const
 
Rect ConvertFromScreen (const Rect &cRect) const
 
void ConvertFromScreen (Rect *cRect) const
 
void Invalidate (const Rect &cRect, bool bRecurse=false)
 Add a rectangle to the damage list. More...
 
void Invalidate (bool bRecurse=false)
 Invalidate the whole view. More...
 
void Flush ()
 Flush the render queue. More...
 
void Sync ()
 Flush the render queue. More...
 
void SetDrawingMode (drawing_mode nMode)
 
drawing_mode GetDrawingMode () const
 
void SetFont (Font *pcFont)
 Change the views text font. More...
 
FontGetFont () const
 
void SetFgColor (int nRed, int nGreen, int nBlue, int nAlpha=255)
 
void SetFgColor (Color32_s sColor)
 
Color32_s GetFgColor () const
 
void SetBgColor (int nRed, int nGreen, int nBlue, int nAlpha=255)
 
void SetBgColor (Color32_s sColor)
 
Color32_s GetBgColor () const
 
void SetEraseColor (int nRed, int nGreen, int nBlue, int nAlpha=255)
 
void SetEraseColor (Color32_s sColor)
 
Color32_s GetEraseColor () const
 
void MovePenTo (const Point &cPos)
 
void MovePenTo (float x, float y)
 
void MovePenBy (const Point &cPos)
 
void MovePenBy (float x, float y)
 
Point GetPenPosition () const
 Get the current pen position. More...
 
void DrawLine (const Point &cToPoint)
 
void DrawLine (const Point &cFromPnt, const Point &cToPnt)
 
virtual void ScrollBy (const Point &cDelta)
 
virtual void ScrollBy (float vDeltaX, float vDeltaY)
 
virtual void ScrollTo (Point cTopLeft)
 
virtual void ScrollTo (float x, float y)
 
Point GetScrollOffset () const
 
void ScrollRect (const Rect &cSrcRect, const Rect &cDstRect)
 Copy a rectangle from one location to another within the view. More...
 
void FillRect (const Rect &cRect)
 
void FillRect (const Rect &cRect, Color32_s sColor)
 
void DrawBitmap (const Bitmap *pcBitmap, const Rect &cSrcRect, const Rect &cDstRect)
 Render a bitmap into the view. More...
 
void EraseRect (const Rect &cRect)
 
void DrawFrame (const Rect &cRect, uint32 nFlags)
 
void DrawRoundedFrame (const os::Rect &cReizeFrame=os::Rect(1, 4,-1,-4), const os::Color32_s &cColor=get_default_color(COL_SHADOW))
 
void DrawRoundedFrame (const os::Rect &cFrame, const os::Rect &cReizeFrame=os::Rect(1, 4,-1,-4), const os::Color32_s &cColor=get_default_color(COL_SHADOW))
 
void DrawString (const Point &cPos, const String &cString)
 
void DrawString (const String &cString)
 Render a text-string at the current pen position. More...
 
void DrawString (const char *pzStr, int Len=-1)
 
void DrawText (const Rect &cPos, const String &cString, uint32 nFlags=0)
 Render a text-string in a specified rectangle. More...
 
void DrawSelectedText (const Rect &cPos, const String &cString, const IPoint &cSel1, const IPoint &cSel2, uint32 nMode=SEL_CHAR, uint32 nFlags=0)
 
void GetSelection (const String &cClipboard="__system_clipboard__")
 
void GetTruncatedStrings (const char **pazStringArray, int nStringCount, uint32 nMode, float nWidth, char **pazResultArray) const
 
float GetStringWidth (const String &cString) const
 
float GetStringWidth (const char *pzString, int nLen=-1) const
 
void GetStringWidths (const char **apzStringArray, const int *anLengthArray, int nStringCount, float *avWidthArray) const
 
Point GetTextExtent (const String &cString, uint32 nFlags=0, int nTargetWidth=-1) const
 
int GetStringLength (const String &cString, float vWidth, bool bIncludeLast=false) const
 
int GetStringLength (const char *pzString, int nLen, float vWidth, bool bIncludeLast=false) const
 
void GetStringLengths (const char **apzStringArray, const int *anLengthArray, int nStringCount, float vWidth, int *anMaxLengthArray, bool bIncludeLast=false) const
 
void GetFontHeight (font_height *psHeight) const
 
void Ping (int nSize=0) const
 
void SetToolTip (const os::String &t)
 
os::String GetToolTip () const
 
Point ConvertToParent (const Point &cPoint) const
 Translate a os::Point into our parents coordinate system. More...
 
void ConvertToParent (Point *cPoint) const
 Translate a os::Point into our parents coordinate system. More...
 
Rect ConvertToParent (const Rect &cRect) const
 
void ConvertToParent (Rect *cRect) const
 
- Public Member Functions inherited from os::Handler
 Handler (const String &cName)
 Construct a handler. More...
 
virtual ~Handler ()
 Destructor. More...
 
virtual void TimerTick (int nID)
 Timer dispatch member. More...
 
virtual void HandleMessage (Message *pcMessage)
 Handle a message targeted at this handler. More...
 
String GetName () const
 Get the handlers name. More...
 
void SetName (const String &cName)
 Rename the handler. More...
 
LooperGetLooper () const
 Get a pointer to the looper this handler belongs to. More...
 
void SetNextHandler (Handler *pcNextHandler)
 Set a handler that should handle messages this handler is not interrested in. More...
 
HandlerGetNextHandler () const
 Get the next handler in a handler chain. More...
 
void AddFilter (MessageFilter *pcFilter)
 
void RemoveFilter (MessageFilter *pcFilter)
 
const MsgFilterListGetFilterList () const
 
const uint32 GetToken ()
 Get the handlers token. More...
 
- Public Member Functions inherited from os::Invoker
 Invoker ()
 Default constructor. More...
 
 Invoker (Message *pcMessage)
 Constructor. More...
 
 Invoker (Message *pcMessage, const Handler *pcHandler, const Looper *pcLooper=NULL)
 Constructor. More...
 
 Invoker (Message *pcMessage, const Messenger &cTarget)
 Constructor. More...
 
virtual ~Invoker ()
 Destructor. More...
 
virtual status_t SetMessage (Message *pcMessage)
 Assign a new message to the invoker. More...
 
MessageGetMessage () const
 Get the message currently assigned to the invoker. More...
 
uint32 GetCode () const
 Get the code field from the currently assigned message. More...
 
virtual void TargetChanged (const Messenger &cOldTarget)
 Virtual hook called by the system after the target has been changed. More...
 
virtual void MessageChanged (const Message &cOldMsg)
 Virtual hook called by the system after the message has been changed. More...
 
virtual status_t SetTarget (const Handler *pcHandler, const Looper *pcLooper=NULL)
 Set a new message target. More...
 
virtual status_t SetTarget (const Messenger &cMessenger)
 Set a new message target. More...
 
bool IsTargetLocal () const
 Check if the target lives in our process. More...
 
HandlerGetTarget (Looper **ppcLooper=NULL) const
 Get the current target. More...
 
Messenger GetMessenger () const
 Get the messenger used to target messages sendt by the invoker. More...
 
virtual status_t SetHandlerForReply (Handler *pcHandler)
 Set a reply target for messages sendt by this messenger. More...
 
HandlerGetHandlerForReply () const
 Get the current reply target for replies on messages sendt by the invoker. More...
 
virtual status_t Invoke (Message *pcMessage=NULL)
 Send the current message to the current target. More...
 

Friends

class ListViewContainer
 
class ListViewHeader
 

Detailed Description

Description:
See Also
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Member Typedef Documentation

typedef std::vector<int> os::ListView::column_map

Member Enumeration Documentation

anonymous enum
Enumerator
AUTOSCROLL_BORDER 
anonymous enum
Enumerator
F_MULTI_SELECT 
F_NO_AUTO_SORT 
F_RENDER_BORDER 
F_DONT_SCROLL 
F_NO_HEADER 
F_NO_COL_REMAP 
F_NO_SORT 
anonymous enum
Enumerator
INV_HEIGHT 
INV_WIDTH 
INV_VISUAL 
Enumerator
SCROLL_UP 
SCROLL_DOWN 

Constructor & Destructor Documentation

ListView::ListView ( const Rect cFrame,
const String cTitle,
uint32  nModeFlags = F_MULTI_SELECT | F_RENDER_BORDER,
uint32  nResizeMask = CF_FOLLOW_LEFT | CF_FOLLOW_TOP,
uint32  nFlags = WID_WILL_DRAW | WID_FULL_UPDATE_ON_RESIZE 
)
ListView::~ListView ( )

Member Function Documentation

void ListView::AllAttached ( void  )
virtual
ListView::const_iterator ListView::begin ( ) const
void ListView::Clear ( )
Description:
Clears the ListView for all rows.
Author
Kurt Skauen

References os::View::Flush(), and os::ListView::Private::m_pcMainView.

Referenced by os::TreeView::Clear().

void ListView::ClearSelection ( )
bool ListView::DragSelection ( const Point cPos)
virtual

Reimplemented in os::DirectoryView.

void ListView::EnableStatusChanged ( bool  bIsEnabled)
virtual

Implements os::Control.

ListView::const_iterator ListView::end ( ) const
Description:
Returns iterator pointing past the last row.
Author
Kurt Skauen

References os::ListView::Private::m_pcMainView.

void ListView::FrameSized ( const Point cDelta)
virtual
Description:
Overload this member if you need to know when the view is resized.
Note:
This member is called after the view is resized. If you need the old size you can subtract the cDelta calue from the current size.
Parameters
cDeltaThe distance the bottom/right corner was moved relative to the upper/left corner.
See Also
FrameMoved(), SetFrame, ResizeBy(), ResizeTo()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

References os::View::Flush(), os::View::GetBounds(), os::View::GetFrame(), os::View::GetScrollOffset(), os::ListView::Private::m_pcHeaderView, os::ListView::Private::m_pcMainView, os::Rect::right, os::View::SetFrame(), and os::Point::x.

const std::vector< int > & ListView::GetColumnMapping ( ) const
int ListView::GetFirstSelected ( ) const
Description:
Returns index to the first select row, or -1 if none is selected.
Author
Kurt Skauen

References os::ListView::Private::m_pcMainView.

Message * ListView::GetInvokeMsg ( ) const
int ListView::GetLastSelected ( ) const
ListViewRow * ListView::GetRow ( const Point cPos) const
Description:
Returns a pointer to the row that is located at cPos, or NULL if no row was found at that position. Can for example be used to implement pop-up menus.
Parameters
cPosCoordinates referenced to ListView control.
Author
Kurt Skauen

References os::ListView::Private::m_pcMainView, and os::Point::y.

Referenced by os::TreeView::Collapse(), os::TreeView::Expand(), os::TreeView::GetChild(), os::TreeView::GetChildren(), os::TreeView::GetNext(), os::TreeView::GetParent(), os::TreeView::GetPrev(), and os::TreeView::HasChildren().

ListViewRow * ListView::GetRow ( uint  nIndex) const
Description:
Returns the a pointer to the row at index nIndex or NULL if the index is out of bounds.
Parameters
nIndexRow index.
Author
Kurt Skauen

References os::ListView::Private::m_pcMainView.

uint ListView::GetRowCount ( ) const
float ListView::GetRowPos ( int  nRow)
Description:
Returns the vertical position, in reference to the ListView control, of a row with index nRow, or 0.0 if no row was found at that position.
Parameters
nRowRow index to look at.
Author
Kurt Skauen

References os::View::GetFrame(), os::View::GetScrollOffset(), os::ListView::Private::m_pcMainView, os::Rect::top, and os::Point::y.

Message * ListView::GetSelChangeMsg ( ) const
bool ListView::HasBorder ( ) const
bool ListView::HasColumnHeader ( ) const
bool ListView::HasFocus ( void  ) const
virtual
void ListView::Highlight ( int  nFirst,
int  nLast,
bool  bReplace,
bool  bHighlight = true 
)
void ListView::Highlight ( int  nRow,
bool  bReplace,
bool  bHighlight = true 
)

References Highlight().

int ListView::HitTest ( const Point cPos) const
Description:
Returns the row index to the row that is located at cPos, or -1 if no row was found at that position. Can for example be used to implement pop-up menus.
Parameters
cPosScreen coordinate to look for a row at.
Author
Kurt Skauen

References os::View::ConvertFromScreen(), os::View::ConvertToScreen(), os::ListView::Private::m_pcMainView, and os::Point::y.

int ListView::InsertColumn ( const char *  pzTitle,
int  nWidth,
int  nPos = -1 
)
void ListView::InsertRow ( int  nPos,
ListViewRow pcRow,
bool  bUpdate = true 
)
Description:
Insert a row at a specific position.
Parameters
nPosRow index.
bUpdateUpdate display. If many operations are performed, often only the last one need to update the display.
Author
Kurt Skauen

References os::View::Flush(), and os::ListView::Private::m_pcMainView.

Referenced by os::TreeView::InsertNode(), and InsertRow().

void ListView::InsertRow ( ListViewRow pcRow,
bool  bUpdate = true 
)
Description:
Insert a row at the end of the list.
Parameters
bUpdateUpdate display. If many operations are performed, often only the last one need to update the display.
Author
Kurt Skauen

References InsertRow().

void ListView::InvalidateRow ( int  nRow,
uint32  nFlags 
)
Description:
This method causes a row to be redrawn.
Parameters
nIndexRow index.
nFlagsFlags. Use INV_VISUAL.
Author
Kurt Skauen

References os::View::Flush(), and os::ListView::Private::m_pcMainView.

bool ListView::Invoked ( Message pcMessage)
virtual
Description:
This member is called from Invoke() just before a message is sendt to the target.
This allow classes that inherits from os::Invoker to add data to or otherwhice modify the message before it is sendt. The message can also be canceled entirely by returning false from this member.
The message passed to Invoked() is a copy of the internal message or the message passed to Invoke() (if any) so any changes made here will not affect the internal message or the message passed to Invoke(). When this method returns the message will imidiatly be sendt to the target and then discarded (unless false is returned in which case the message is simply discarded).
The default implementation of this member does nothing and return true.
Parameters
pcMessagePointer to the message that is about to be sendt. You can do any modification you like to this message (but never delete it).
Returns
Normally you should return true to indicate that the message should be sendt. You can however return false if you for some reason want to cancel the invokation.
See Also
Invoke(), SetMessage(), SetTarget()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::Control.

References os::Control::Invoked().

void ListView::Invoked ( int  nFirstRow,
int  nLastRow 
)
virtual
bool ListView::IsAutoSort ( ) const
bool ListView::IsMultiSelect ( ) const
bool ListView::IsSelected ( uint  nRow) const
Description:
Returns true if nRow is selected.
Parameters
nRowRow to check.
Author
Kurt Skauen

References os::ListView::Private::m_pcMainView.

void ListView::KeyDown ( const char *  pzString,
const char *  pzRawString,
uint32  nQualifiers 
)
virtual
Description:
Overload this member if your view need to handle keyboard input. This member is called to allow the view to handle M_KEY_DOWN messages. The most common members are exctracted from the message and passed as parameters but you might need to obtain the raw message with os::Looper::GetCurrentMessage() and find some members yourself if you the data you needed are not passed in.
For example if you need the raw key-code for the pressed key you will have to lookup the "_raw_key" member from the message.
Parameters
pzStringString containing a single UTF-8 encoded character. This is the character generated by the pressed key according to the current keymap accounting for any qualifiers that might be pressed.
pzRawStringSame as pzString except that the key is converted without accounting for qualifiers. Ie. if 'A' is pressed while pressing <SHIFT> pzString will contain 'A' and pzRawString will contain 'a'.
nQualifiersBitmask describing which qualifiers that was active when the key was pressed.
See Also
KeyUp(), os::Looper::GetCurrentMessage()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

Reimplemented in os::DirectoryView.

References os::View::KeyDown(), and os::ListView::Private::m_pcMainView.

void ListView::LabelChanged ( const String cNewLabel)
virtual

Reimplemented from os::Control.

void ListView::MakeVisible ( int  nRow,
bool  bCenter = true 
)
Description:
Scroll the ListView so that a row becomes visible.
Parameters
nRowIndex to row to make visible.
bCenterSet to true to have the view centred on nRow.
Author
Kurt Skauen

References os::View::Flush(), and os::ListView::Private::m_pcMainView.

void ListView::MouseDown ( const Point cPosition,
uint32  nButtons 
)
virtual
Description:
This member is called from the window thread whenever a mouse button is clicked above the view. You can overload this member if your view need to know about mouse-down events.
A view will not automatically take focus when clicked so if you want that behaviour you must call MakeFocus() from an overloaded version of this member.
The default implementation of this member will call MouseDown() on it's parent view if one exists.
Parameters
cPositionMouse position in the views coordinate system at the time the mouse was pressed.
nButtonsIndex of the pressed button. Buttons start at 1 for the left button, 2 for the right button, 3 for the middle button. Additional buttons might be supported by the mouse driver and will then be assigned numbers from 4 and up.
See Also
MouseUp(), MouseMove(), WheelMoved()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

References os::View::MouseDown().

void ListView::MouseMove ( const Point cNewPos,
int  nCode,
uint32  nButtons,
Message pcData 
)
virtual
Description:
This member is called from the window thread whenever the mouse is moved above the view or if the view has focus.
Oveload this member if your view need to handle mouse-move events.
The default implementation of this member will call MouseMove() on it's parent view if one exists.
Parameters
cNewPosNew mouse position given in the views coordinate system.
nCodeEnter/exit code. This is MOUSE_ENTERED when the mouse first enter the view, MOUSE_EXITED when the mouse leaves the view, MOUSE_INSIDE whenever the mouse move withing the boundary of the view and MOUSE_OUTSIDE when the mouse move outside the view (will only happen if the view has focus).
nButtonsBitmask telling which buttons that are currently pressed. Bit 0 is button 1 (left), bit 1 is button 2 (right), and bit 2 is button 3 (middle), and so on.
pcDataPointer to a Message object containing the dragged data if the user is in the middle of a drag and drop operation. Otherwise this pointer is NULL. Look at BeginDrag() for a more detailed description of the drag and drop system.
See Also
MouseDown(), MouseUp(), WheelMoved(), BeginDrag()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

Reimplemented in os::DirectoryView.

References os::View::MouseMove().

void ListView::MouseUp ( const Point cPosition,
uint32  nButtons,
Message pcData 
)
virtual
Description:
This member is called from the window thread whenever a mouse button is released above the view. You can overload this member if your view need to know about mouse-up events or if your view support drag and drop.
If mouse-up was the result of ending a drag and drop operation the pcData member will point to a Message containing the dragged data. Look at BeginDrag() for a more detailed description of the drag and drop system.
The default implementation of this member will call MouseDown() on it's parent view if one exists.
Parameters
cPositionMouse position in the views coordinate system at the time the mouse was pressed.
nButtonsIndex of the pressed button. Buttons start at 1 for the left button, 2 for the right button, 3 for the middle button. Additional buttons might be supported by the mouse driver and will then be assigned numbers from 4 and up.
pcDataPointer to a Message object containing the dragged data if this mouse-up was the end of a drag and drop operation. If no data was dragged it will be NULL.
See Also
MouseDown(), MouseMove(), WheelMoved()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

Reimplemented in os::DirectoryView.

References os::View::MouseUp().

void ListView::Paint ( const Rect cUpdateRect)
virtual
Description:
Note:
Warning:
Parameters
cUpdateRectA rectangle enclosing all damaged areas. This is just a rough "worst-case", further fine-grained clipping will be performed by the Application Server to avoid updating non-damaged pixels and make the update as fast and flicker-free as possible.
See Also
Invalidate(), Flush()
Author
Kurt Skauen (kurt@.nosp@m.athe.nosp@m.os.cx)

Reimplemented from os::View.

Reimplemented in os::TreeView.

References os::Rect::bottom, os::COL_NORMAL, os::View::DrawFrame(), F_RENDER_BORDER, os::View::FillRect(), os::FRAME_RECESSED, os::FRAME_TRANSPARENT, os::get_default_color(), os::View::GetBounds(), os::View::GetFrame(), os::ListView::Private::m_pcHScroll, os::ListView::Private::m_pcMainView, os::ListView::Private::m_pcVScroll, and os::Rect::right.

Referenced by os::TreeView::Paint().

void ListView::RefreshLayout ( )
Description:
Calculates new positions for all rows, invalidates them so that they are rendered, and adjusts scrollbars. Normally there is no reason to use this function, it is primarily implemented for use by the TreeView class.
Author
Henrik Isaksson (henri.nosp@m.k@is.nosp@m.aksso.nosp@m.n.tk)

References os::View::Flush(), os::View::Invalidate(), os::ListView::Private::m_pcMainView, and os::View::Sync().

Referenced by os::TreeView::Collapse(), os::TreeView::Expand(), and Sort().

ListViewRow * ListView::RemoveRow ( int  nIndex,
bool  bUpdate = true 
)
Description:
Removes a row from the ListView. A pointer to the removed row is returned, and the application is responsible for freeing it.
Parameters
nIndexRow index.
bUpdateUpdate display. If many operations are performed, often only the last one need to update the display.
Author
Kurt Skauen

References os::View::Flush(), and os::ListView::Private::m_pcMainView.

Referenced by os::TreeView::RemoveRow().

void ListView::Select ( int  nFirst,
int  nLast,
bool  bReplace = true,
bool  bSelect = true 
)
void ListView::Select ( int  nRow,
bool  bReplace = true,
bool  bSelect = true 
)

References Select().

void ListView::SelectionChanged ( int  nFirstRow,
int  nLastRow 
)
virtual
void ListView::SetAutoSort ( bool  bAuto)
void ListView::SetColumnMapping ( const column_map cMap)
void ListView::SetCurrentRow ( int  nRow)
void ListView::SetHasColumnHeader ( bool  bFlag)
Description:
Use this method to specify if a column header should be drawn.
See Also
HasColumnHeader()
Author
Kurt Skauen

References F_NO_HEADER, os::View::Flush(), and os::ListView::Private::m_pcMainView.

void ListView::SetInvokeMsg ( Message pcMsg)
void ListView::SetMultiSelect ( bool  bMulti)
void ListView::SetRenderBorder ( bool  bRender)
void ListView::SetSelChangeMsg ( Message pcMsg)
void ListView::Sort ( )
Description:
Sort rows in the ListView by the selected column, according to ListViewRow::IsLessThan(). The actual sorting takes place in SortRows(), which can be overridden to provide custom sorting routines.
See Also
SortRows()
Author
Kurt Skauen, Henrik Isaksson (henri.nosp@m.k@is.nosp@m.aksso.nosp@m.n.tk)

References os::ListView::Private::m_pcMainView, RefreshLayout(), and SortRows().

void ListView::SortRows ( std::vector< ListViewRow * > *  pcRows,
int  nColumn 
)
virtual
Description:
Overridable default sorting routine.
Parameters
pcRowsstd::vector of ListViewRows to be sorted.
nColumnThe column to sort by.
See Also
Sort()
Author
Henrik Isaksson (henri.nosp@m.k@is.nosp@m.aksso.nosp@m.n.tk)

Reimplemented in os::TreeView.

Referenced by Sort().

void ListView::StartScroll ( scroll_direction  eDirection,
bool  bSelect 
)
void ListView::StopScroll ( )

Friends And Related Function Documentation

friend class ListViewContainer
friend
friend class ListViewHeader
friend

Referenced by ListView().