+++ /dev/null
-/////////////////////////////////////////////////////////////////////////////
-// Name: tabpgwin.cpp
-// Purpose: Contrib. demo
-// Author: Aleksandras Gluchovas
-// Modified by: 19990908 : mj
-// - rename to tabpgwin
-// - restruction of Variable declaration
-// - to prevent Warnings under MingW32
-// Modified by: 19990909 : mj
-// - mNoVertScroll true = no / false = Original Code
-// the Original Code Paints a Vertical Scroll in wxPagedWindow
-// which is not needed in this Version. Use true for this.
-// Created: 07/09/98
-// RCS-ID: $Id$
-// Copyright: (c) Aleksandras Gluchovas
-// Licence: wxWindows license
-/////////////////////////////////////////////////////////////////////////////
-
-// For compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
-#pragma hdrstop
-#endif
-
-#ifndef WX_PRECOMP
-#include "wx/wx.h"
-#endif
-
-#include "wx/math.h"
-
-#include <stdlib.h>
-
-#include "wx/string.h"
-#include "wx/utils.h" // import wxMin/wxMax macros and wxFileExist(..)
-
-#include "tabpgwin.h"
-
-//---------------------------------------------------------------------------
-// Implementation for class twTabInfo
-//---------------------------------------------------------------------------
-IMPLEMENT_DYNAMIC_CLASS( twTabInfo, wxObject )
-
-//---------------------------------------------------------------------------
-twTabInfo::twTabInfo()
-: mpContent( 0 )
-{}
-
-//---------------------------------------------------------------------------
-int twTabInfo::ImgWidth()
-{
- if ( mBitMap.Ok() ) return mBitMap.GetWidth();
- else return 0;
-}
-
-//---------------------------------------------------------------------------
-int twTabInfo::ImgHeight()
-{
- if ( mBitMap.Ok() )
- return mBitMap.GetHeight();
- else
- return 0;
-}
-
-//---------------------------------------------------------------------------
-int twTabInfo::ImageToTxtGap( int prefGap )
-{
- if ( mBitMap.Ok() )
- return prefGap;
- else
- return 0;
-}
-
-//---------------------------------------------------------------------------
-bool twTabInfo::HasImg()
-{
- return mBitMap.Ok();
-}
-
-//---------------------------------------------------------------------------
-// bool twTabInfo::HasText();
-unsigned int twTabInfo::HasText()
-{
- return mText.Length();
-}
-
-//---------------------------------------------------------------------------
-wxBitmap& twTabInfo::GetImg()
-{
- return mBitMap;
-}
-
-//---------------------------------------------------------------------------
-wxString& twTabInfo::GetText()
-{
- return mText;
-}
-
-//---------------------------------------------------------------------------
-wxWindow& twTabInfo::GetContent()
-{
- return *mpContent;
-}
-
-//---------------------------------------------------------------------------
-// Implementation for class wxTabbedWindow
-//---------------------------------------------------------------------------
-IMPLEMENT_DYNAMIC_CLASS( wxTabbedWindow, wxPanel )
-
-//---------------------------------------------------------------------------
-BEGIN_EVENT_TABLE( wxTabbedWindow, wxPanel )
- EVT_SIZE ( wxTabbedWindow::OnSize )
- EVT_PAINT( wxTabbedWindow::OnPaint )
- EVT_LEFT_DOWN( wxTabbedWindow::OnLButtonDown )
- // TDB:: filciker reduction
- // EVT_ERASE_BACKGROUND( wxTabbedWindow::OnBkErase )
-END_EVENT_TABLE()
-
-//---------------------------------------------------------------------------
-wxTabbedWindow::wxTabbedWindow()
-
-: mpTabScroll ( NULL ),
- mpHorizScroll( NULL ),
- mpVertScroll ( NULL ),
-
- mVertGap ( 0 ),
- mHorizGap( 0 ),
-
- mTitleVertGap ( 3 ),
- mTitleHorizGap( 4 ),
- mImageTextGap ( 2 ),
- mFirstTitleGap( 11 ),
-
- mBorderOnlyWidth( 8 ),
-
- mWhitePen( wxColour(255,255,255), 1, wxSOLID ),
- mGrayPen ( wxColour(192,192,192), 1, wxSOLID ),
- mDarkPen ( wxColour(128,128,128), 1, wxSOLID ),
- mBlackPen( wxColour( 0, 0, 0), 1, wxSOLID ),
-
- // state variables
- mActiveTab ( 0 ),
- mTitleHeight( 0 ),
- mLayoutType( wxTITLE_IMG_AND_TEXT )
-{}
-
-//---------------------------------------------------------------------------
-wxTabbedWindow::~wxTabbedWindow()
-{
- wxObjectList::compatibility_iterator pTab = mTabs.GetFirst();
-
- while( pTab )
- {
- delete ((twTabInfo*)pTab->GetData());
- pTab = pTab->GetNext();
- }
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::SizeTabs(int x,int y, int width, int height, bool WXUNUSED(repant))
-{
- wxObjectList::compatibility_iterator pTabNode = mTabs.GetFirst();
- size_t n = 0;
-
- while( pTabNode )
- {
- twTabInfo& info = *((twTabInfo*)pTabNode->GetData());
-
- if ( n == mActiveTab )
- {
- //wxSizeEvent evt;
- //info.mpContent->GetEventHandler()->ProcessEvent( evt );
-
- info.mpContent->SetSize( x, y, width, height, 0 );
- info.mpContent->Show(true);
- info.mpContent->Refresh();
-
- }
- else
- {
- info.mpContent->Show(false);
- }
-
- pTabNode = pTabNode->GetNext();
- ++n;
- }
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::AddTab( wxWindow* pContent,
- wxString tabText,
- wxString imageFileName,
- wxBitmapType imageType )
-{
- twTabInfo* pTab = new twTabInfo();
-
- pTab->mpContent = pContent;
- pTab->mText = tabText;
-
- if ( wxFileExists( imageFileName ) &&
-
- pTab->mBitMap.LoadFile( imageFileName, imageType ) )
- {
- pTab->mImageFile = imageFileName;
- pTab->mImageType = imageType;
- }
-
-
- if ( pContent->GetParent() == NULL )
- pContent->Create( this, wxID_ANY );
-
- mTabs.Append( (wxObject*)pTab );
-
- RecalcLayout(true);
-
- OnTabAdded( pTab );
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::AddTab( wxWindow* pContent,
- wxString tabText, wxBitmap* pImage )
-{
- twTabInfo* pTab = new twTabInfo();
-
- pTab->mpContent = pContent;
- pTab->mText = tabText;
-
- if ( pImage )
- pTab->mBitMap = *pImage;
-
- if ( pContent->GetParent() == NULL )
- pContent->Create( this, wxID_ANY );
-
- mTabs.Append( (wxObject*)pTab );
- RecalcLayout(true);
- OnTabAdded( pTab );
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::RemoveTab( int tabNo )
-{
- twTabInfo* pTab = ((twTabInfo*)(mTabs.Item( tabNo )->GetData()));
- pTab->mpContent->Destroy();
- delete pTab;
- mTabs.Erase( mTabs.Item( tabNo ) );
- // if ( mActiveTab >= mTabs.GetCount() );
- if ( mActiveTab >= mTabs.GetCount() )
- mActiveTab = mTabs.GetCount() - 1;
- SetActiveTab( mActiveTab );
-}
-
-//---------------------------------------------------------------------------
-int wxTabbedWindow::GetTabCount()
-{
- return mTabs.GetCount();
-}
-
-//---------------------------------------------------------------------------
-wxWindow* wxTabbedWindow::GetTab( int tabNo )
-{
- return ((twTabInfo*)(mTabs.Item( tabNo )->GetData()))->mpContent;
-}
-
-//---------------------------------------------------------------------------
-wxWindow* wxTabbedWindow::GetActiveTab()
-{
- // FIMXE:: this is lame
- return GetTab( mActiveTab );
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::SetActiveTab( int tabNo )
-{
- mActiveTab = tabNo;
- RecalcLayout(true);
- Refresh();
-}
-
-//---------------------------------------------------------------------------
-// width of the decorations border (4 shade-lines), should not be changed
-//---------------------------------------------------------------------------
-#define BORDER_SZ 4
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::DrawShadedRect( int x, int y, int width, int height,
- wxPen& upperPen, wxPen& lowerPen, wxDC& dc
- )
-{
- // darw the lightened upper-left sides of the rectangle
-
- dc.SetPen( upperPen );
- dc.DrawLine( x,y, x, y + height - 1 ); // vert
- dc.DrawLine( x,y, x + width - 1, y ); // horiz
-
- // draw the unenlightened lower-right sides of the rectangle
-
- dc.SetPen( lowerPen );
- dc.DrawLine( x + width - 1, y, x + width - 1, y + height - 1 ); // vert
- dc.DrawLine( x, y + height - 1, x + width, y + height - 1 ); // horiz
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::DrawDecorations( wxDC& dc )
-{
- // Protability NOTE::: DrawLine(..) draws a line from the first position,
- // but not including the point specified by last position.
- // This way Windows draws lines, not sure how Motif and Gtk
- // prots behave...
-
- int width, height;
- GetClientSize( &width, &height );
-
- // check if there's at least a bit of space to draw things
-
- if ( width < mHorizGap*2 + BORDER_SZ*2+1 ||
- height < mVertGap*2 + BORDER_SZ*2+1 + mTitleHeight
- )
- return;
-
- // step #1 - draw border around the tab content area
-
- // setup position for kind of "pencil"
- int curX = mHorizGap;
- int curY = mVertGap;
-
- int xSize = width - mHorizGap*2;
- int ySize = height - mVertGap *2 - mTitleHeight;
-
- // layer 1 (upper white)
- DrawShadedRect( curX+0, curY+0, xSize-0, ySize-0,
- mWhitePen, mBlackPen, dc );
-
- // layer 2 (upper gray)
- DrawShadedRect( curX+1, curY+1, xSize-2-1, ySize-2-1,
- mGrayPen, mGrayPen, dc );
-
- // layer 3 (upper darkGray)
- DrawShadedRect( curX+2, curY+2, xSize-3-2, ySize-3-2,
- mDarkPen, mWhitePen, dc );
-
- // layer 4 (upper black)
- DrawShadedRect( curX+3, curY+3, xSize-4-3, ySize-4-3,
- mBlackPen, mGrayPen, dc );
-
- // add non-siemtric layer from the lower-right side (confroming to MFC-look)
-
- dc.SetPen( mDarkPen );
- dc.DrawLine( curX+1, curY + ySize - 2, curX + xSize - 1, curY + ySize - 2 ); // horiz
- dc.DrawLine( curX + xSize - 2, curY + 1, curX + xSize - 2, curY + ySize - 2 ); // vert
-
- // step #2 - draw tab title bars
-
- curX = mFirstTitleGap;
- curY = height - mVertGap - mTitleHeight;
-
- size_t tabNo = 0;
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
-
- while( pNode )
- {
- // "hard-coded metafile" for decorations
-
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- xSize = tab.mDims.x;
- ySize = mTitleHeight;
-
- if ( tabNo == mActiveTab )
- {
- dc.SetPen( mGrayPen );
- dc.DrawLine( curX+1, curY-2, curX+xSize-2, curY-2 );
- dc.DrawLine( curX+1, curY-1, curX+xSize-2, curY-1 );
- }
-
- dc.SetPen( mWhitePen );
-
- if ( tabNo == mActiveTab )
- dc.DrawLine( curX, curY-2, curX, curY+ySize-2 );
- else
- dc.DrawLine( curX, curY, curX, curY+ySize-2 );
-
- dc.SetPen( mDarkPen );
- dc.DrawLine( curX+1, curY+ySize-3, curX+1, curY+ySize-1 ); // to pix down
- dc.DrawLine( curX+2, curY+ySize-2, curX+xSize-2, curY+ySize-2 );
- dc.DrawLine( curX+xSize-3, curY+ySize-3, curX+xSize-2, curY+ySize-3 );
- if ( tabNo == mActiveTab )
- dc.DrawLine( curX+xSize-2, curY+ySize-3, curX+xSize-2, curY-3 );
- else
- dc.DrawLine( curX+xSize-2, curY+ySize-3, curX+xSize-2, curY-1 );
-
- dc.SetPen( mBlackPen );
- dc.DrawLine( curX+xSize-1, curY, curX+xSize-1, curY+ySize-2 );
- dc.DrawLine( curX+xSize-2, curY+ySize-2, curX+xSize-3, curY+ySize-2 );
- dc.DrawLine( curX+xSize-3, curY+ySize-1, curX+1, curY+ySize-1 );
-
- pNode = pNode->GetNext();
- ++tabNo;
-
- // darw image and (or without) text centered within the
- // title bar rectangle
-
- if ( mLayoutType != wxTITLE_BORDER_ONLY && tab.HasImg() )
- {
- wxMemoryDC tmpDc;
- tmpDc.SelectObject( tab.GetImg() );
-
- dc.Blit( curX + mTitleHorizGap,
- curY + ( ySize - tab.ImgHeight() ) / 2,
- tab.ImgWidth(),
- tab.ImgHeight(),
- &tmpDc, 0, 0, wxCOPY
- );
- }
-
- if ( mLayoutType == wxTITLE_IMG_AND_TEXT && tab.HasText() )
- {
- long x,w,h;
-
- // set select default font of the window into it's device context
- //dc.SetFont( GetLabelingFont() );
-
- dc.SetTextBackground( GetBackgroundColour() );
-
- dc.GetTextExtent(tab.mText, &w, &h );
-
- x = curX + mTitleHorizGap +
- tab.ImgWidth() + tab.ImageToTxtGap(mImageTextGap);
-
- dc.DrawText( tab.GetText(), x, curY + ( ySize - h ) / 2 );
- }
- curX += xSize;
-
- } // end of `while (pNode)'
-} // wxTabbedWindow::DrawDecorations()
-
-//---------------------------------------------------------------------------
-int wxTabbedWindow::HitTest( const wxPoint& pos )
-{
- int width, height;
- GetClientSize( &width, &height );
-
- int curX = mFirstTitleGap;
- int curY = height - mVertGap - mTitleHeight;
-
- int tabNo = 0;
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- // hit test rectangle of the currnet tab title bar
- if ( pos.x >= curX && pos.x < curX + tab.mDims.x &&
- pos.y >= curY && pos.y < curY + tab.mDims.y
- )
- {
- return tabNo;
- }
-
- curX += tab.mDims.x;
-
- pNode = pNode->GetNext();
- ++tabNo;
- }
-
- return -1;
-} // wxTabbedWindow::HitTest()
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::HideInactiveTabs( bool andRepaint )
-{
- if ( !andRepaint )
- return;
-
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
- size_t tabNo = 0;
-
- while( pNode )
- {
- if ( tabNo != mActiveTab )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
- tab.mpContent->Show(false);
- }
-
- pNode = pNode->GetNext();
- ++tabNo;
- }
-} // wxTabbedWindow::HideInactiveTabs()
-
-//---------------------------------------------------------------------------
-wxFont wxTabbedWindow::GetLabelingFont()
-{
- wxFont font;
-#ifdef __WINDOWS__
- font.SetFaceName(_T("MS Sans Serif"));
-#else
- font.SetFamily( wxSWISS );
-#endif
-
- font.SetStyle(40);
- font.SetWeight(40);
- font.SetPointSize( 8 );
-
-#ifdef __WINDOWS__
- font.RealizeResource();
-#endif
-
- return font;
-} // wxTabbedWindow::GetLabelingFont()
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::RecalcLayout(bool andRepaint)
-{
- HideInactiveTabs(andRepaint);
-
- // resetup position of the active tab
-
- int width, height;
- GetClientSize( &width, &height );
-
- int curX = mHorizGap + BORDER_SZ;
- int curY = mVertGap + BORDER_SZ;
-
- int xSize = width - mHorizGap*2 - BORDER_SZ*2-1;
- int ySize = height - mVertGap*2 - BORDER_SZ*2-1 - mTitleHeight;
-
- SizeTabs( curX, curY, xSize, ySize, andRepaint );
-
- // pass #1 - try to layout assuming it's wxTITLE_IMG_AND_TEXT
-
- mLayoutType = wxTITLE_IMG_AND_TEXT;
-
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
-
- curX = mFirstTitleGap; // the left-side gap
- mTitleHeight = 0;
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- wxWindowDC dc(this);
-
- long w,h;
-
- // set select default font of the window into it's device context
- //dc.SetFont( GetLabelingFont() );
-
- dc.GetTextExtent(tab.mText, &w, &h );
-
- tab.mDims.x = w + tab.ImageToTxtGap(mImageTextGap) +
- tab.ImgWidth() + mTitleHorizGap*2;
-
- tab.mDims.y = wxMax( h, tab.ImgHeight() ) + mTitleVertGap*2;
- mTitleHeight = wxMax( mTitleHeight, tab.mDims.y );
-
- curX += tab.mDims.x;
-
- pNode = pNode->GetNext();
- }
-
- curX += mHorizGap; // the right-side gap
-
- // make all title bars of equel height
-
- pNode = mTabs.GetFirst();
-
- while( pNode )
- {
- ((twTabInfo*)(pNode->GetData()))->mDims.y = mTitleHeight;;
- pNode = pNode->GetNext();
- }
-
- // if curX has'nt ran out of bounds, leave TITLE_IMG layout and return
- if ( curX < width - mHorizGap )
- return;
-
- // pass #2 - try to layout assuming wxTITLE_IMG_ONLY
-
- mLayoutType = wxTITLE_IMG_ONLY;
-
- pNode = mTabs.GetFirst();
-
- curX = mFirstTitleGap; // the left-side gap
-
- int denomiator = mTabs.GetCount();
- if ( denomiator == 0 )
- ++denomiator;
-
- mBorderOnlyWidth = (width - mFirstTitleGap - mHorizGap) / denomiator;
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- if ( tab.HasImg() )
- {
- tab.mDims.x = tab.ImgWidth() + mTitleHorizGap*2;
- tab.mDims.y = tab.ImgHeight() + mTitleVertGap*2;
- }
- else
- {
- tab.mDims.x = mBorderOnlyWidth;
- tab.mDims.y = mTitleHeight;
- }
-
- curX += tab.mDims.x;
-
- pNode = pNode->GetNext();
- }
-
- curX += mHorizGap; // the right-side gap
-
- // if curX has'nt ran out of bounds, leave IMG_ONLY layout and return
- if ( curX < width - mHorizGap )
- return;
-
- // pass #3 - set the narrowest layout wxTITLE_BORDER_ONLY
-
- mLayoutType = wxTITLE_BORDER_ONLY;
-
- pNode = mTabs.GetFirst();
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- tab.mDims.x = mBorderOnlyWidth;
- tab.mDims.y = mTitleHeight;
-
- pNode = pNode->GetNext();
- }
-} // wxTabbedWindow::RecalcLayout()
-
-//---------------------------------------------------------------------------
-// wx event handlers
-//---------------------------------------------------------------------------
-void wxTabbedWindow::OnPaint( wxPaintEvent& WXUNUSED(event) )
-{
- wxPaintDC dc(this);
- DrawDecorations( dc );
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::OnSize ( wxSizeEvent& WXUNUSED(event) )
-{
- SetBackgroundColour( wxColour( 192,192,192 ) );
- RecalcLayout(true);
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::OnBkErase( wxEraseEvent& WXUNUSED(event) )
-{
- // do nothing
-}
-
-//---------------------------------------------------------------------------
-void wxTabbedWindow::OnLButtonDown( wxMouseEvent& event )
-{
- // floats, why?
- int x = (int)event.m_x;
- int y = (int)event.m_y;
-
- int tabNo = HitTest( wxPoint(x,y) );
-
- if ( tabNo != -1 )
- {
- SetActiveTab( tabNo );
- }
-}
-
-//---------------------------------------------------------------------------
-// Implementation for class wxPagedWindow
-//---------------------------------------------------------------------------
-IMPLEMENT_DYNAMIC_CLASS( wxPagedWindow, wxTabbedWindow )
-
-//---------------------------------------------------------------------------
-BEGIN_EVENT_TABLE( wxPagedWindow, wxTabbedWindow )
- EVT_SIZE ( wxPagedWindow::OnSize )
- EVT_PAINT ( wxPagedWindow::OnPaint )
- EVT_LEFT_DOWN( wxPagedWindow::OnLButtonDown )
- EVT_LEFT_UP ( wxPagedWindow::OnLButtonUp )
- EVT_MOTION ( wxPagedWindow::OnMouseMove )
- EVT_SCROLL ( wxPagedWindow::OnScroll )
-END_EVENT_TABLE()
-
-//---------------------------------------------------------------------------
-// border for paged-window is 2 shaded-lines
-//---------------------------------------------------------------------------
-#undef BORDER_SZ
-#define BORDER_SZ 2
-
-//---------------------------------------------------------------------------
-wxPagedWindow::wxPagedWindow()
-
-: mScrollEventInProgress( false ),
- mTabTrianGap(4),
- mWhiteBrush( wxColour(255,255,255), wxSOLID ),
- mGrayBrush ( wxColour(192,192,192), wxSOLID ),
- mCurentRowOfs( 0 ),
- mAdjustableTitleRowLen( 300 ),
- mIsDragged ( false ),
- mDagOrigin ( 0 ),
- mCursorChanged( false ),
- mResizeCursor ( wxCURSOR_SIZEWE ),
- mNormalCursor ( wxCURSOR_ARROW )
-{
- mTitleVertGap = 2;
- mTitleHorizGap = 10;
- mNoVertScroll = true; // Horizontale Scroll abschalten
-}
-
-//---------------------------------------------------------------------------
-wxFont wxPagedWindow::GetLabelingFont()
-{
- wxFont font;
-
-#ifdef __WINDOWS__
- font.SetFaceName(_T("Comic Sans MS"));
-#else
- font.SetFamily( wxSWISS );
-#endif
-
- font.SetStyle(40);
- font.SetWeight(40);
- font.SetPointSize( 8 );
-
- return font;
-}
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnTabAdded( twTabInfo* WXUNUSED(pInfo) )
-{
- int units = GetWholeTabRowLen() / 20;
-
- mpTabScroll->SetScrollbar( 0, 1, units, 1, false );
-}
-
-//---------------------------------------------------------------------------
-wxScrollBar& wxPagedWindow::GetVerticalScrollBar()
-{
- return *mpVertScroll;
-}
-
-//---------------------------------------------------------------------------
-wxScrollBar& wxPagedWindow::GetHorizontalScrollBar()
-{
- return *mpHorizScroll;
-}
-
-//---------------------------------------------------------------------------
-int wxPagedWindow::GetWholeTabRowLen()
-{
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
-
- int len = 0;
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- len += tab.mDims.x;
- pNode = pNode->GetNext();
- }
-
- return len;
-} // wxPagedWindow::GetWholeTabRowLen()
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::DrawPaperBar( twTabInfo& tab, int x, int y,
- wxBrush& brush, wxPen& pen, wxDC& dc )
-{
- wxPoint poly[4];
-
- // draw organizer-style paper outlet
-
- poly[0].x = x - mTabTrianGap;
- poly[0].y = y;
-
- poly[1].x = x + mTabTrianGap;
- poly[1].y = y + tab.mDims.y-1;
-
- poly[2].x = x + tab.mDims.x - mTabTrianGap;
- poly[2].y = y + tab.mDims.y-1;
-
- poly[3].x = x + tab.mDims.x + mTabTrianGap;
- poly[3].y = y;
-
- dc.SetPen( pen );
- dc.SetBrush( brush );
-
- dc.DrawPolygon( 4, poly );
-
- long w,h;
-
- // set select default font of the window into it's device context
- //dc.SetFont( GetLabelingFont() );
-
- dc.SetTextBackground( brush.GetColour() );
-
- dc.GetTextExtent(tab.mText, &w, &h );
-
- if ( tab.HasImg() )
- {
- wxMemoryDC tmpDc;
- tmpDc.SelectObject( tab.GetImg() );
-
- dc.Blit( x + mTitleHorizGap,
- y + ( tab.mDims.y - tab.ImgHeight() ) / 2,
- tab.ImgWidth(),
- tab.ImgHeight(),
- &tmpDc, 0, 0, wxCOPY
- );
- }
-
- if ( tab.HasText() )
- {
- int tx = x + mTitleHorizGap +
- tab.ImgWidth() + tab.ImageToTxtGap(mImageTextGap);
-
- dc.DrawText( tab.GetText(), tx, y + ( tab.mDims.y - h ) / 2 );
- }
-} // wxPagedWindow::DrawPaperBar()
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::DrawDecorations( wxDC& dc )
-{
- // FIXME:: the is big body have to be split!
-
- int width, height;
- GetClientSize( &width, &height );
-
- int curX = mHorizGap;
- int curY = mVertGap;
-
- int xSize = width - mHorizGap*2;
- int ySize = height - mVertGap*2;
-
- DrawShadedRect( curX, curY, xSize, ySize,
- mDarkPen, mWhitePen, dc );
-
- DrawShadedRect( curX+1, curY+1, xSize-2, ySize-2,
- mBlackPen, mGrayPen, dc );
-
- // draw inactive tab title bars frist (left-to-right)
-
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
- size_t tabNo = 0;
-
- /* OLD STUFF::
- curX = mTitleRowStart;
- curY = height - mVertGap - BORDER_SZ - mTitleHeight;
- */
-
- curX = mTabTrianGap;
- curY = 0;
-
- // FOR NOW:: avoid creating bitmap with invalid dimensions
-
- if ( mTitleRowLen < 1 || mTitleHeight < 1 )
- return;
-
- wxMemoryDC tmpDc;
- wxBitmap tmpBmp( mTitleRowLen, mTitleHeight );
-
- tmpDc.SelectObject( tmpBmp );
- tmpDc.SetPen( mGrayPen );
- tmpDc.SetBrush( mGrayBrush );
- tmpDc.DrawRectangle( 0,0, mTitleRowLen, mTitleHeight );
-
- tmpDc.SetDeviceOrigin( mCurentRowOfs, 0 );
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- if ( tabNo != mActiveTab )
- DrawPaperBar( tab, curX, curY, mGrayBrush, mBlackPen, tmpDc );
-
- curX += tab.mDims.x;
-
- pNode = pNode->GetNext();
- ++tabNo;
- }
-
- // finally, draw the active tab (white-filled)
-
- pNode = mTabs.GetFirst();
- tabNo = 0;
-
- curX = mTabTrianGap;
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- if ( tabNo == mActiveTab )
- {
- DrawPaperBar( tab, curX, curY, mWhiteBrush, mBlackPen, tmpDc );
-
- tmpDc.SetPen( mWhitePen );
-
- tmpDc.DrawLine( curX - mTabTrianGap+1, curY,
- curX + tab.mDims.x + mTabTrianGap, curY );
- break;
- }
- curX += tab.mDims.x;
-
- pNode = pNode->GetNext();
- ++tabNo;
- }
-
- // back to initial device origin
-
- tmpDc.SetDeviceOrigin( 0, 0 );
-
- // draw resize-hint-stick
-
- curX = mTitleRowLen - 6;
-
- DrawShadedRect( curX+0, 0+0, 6, mTitleHeight, mGrayPen, mBlackPen, tmpDc );
- DrawShadedRect( curX+1, 0+1, 6-2, mTitleHeight-2, mWhitePen, mDarkPen, tmpDc );
- DrawShadedRect( curX+2, 0+2, 6-4, mTitleHeight-4, mGrayPen, mGrayPen, tmpDc );
-
-
-
- dc.Blit( mTitleRowStart,
- height - mVertGap - BORDER_SZ - mTitleHeight,
- mTitleRowLen, mTitleHeight,
- &tmpDc, 0,0, wxCOPY );
-} // wxPagedWindow::DrawDecorations()
-
-//---------------------------------------------------------------------------
-int wxPagedWindow::HitTest( const wxPoint& pos )
-{
- return wxTabbedWindow::HitTest( pos );
-}
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::RecalcLayout(bool andRepaint)
-{
- mTitleRowLen = mAdjustableTitleRowLen;
-
- if ( int(mpTabScroll) == -1 ) return;
-
- // scroll bars should be created after Create() for this window is called
- if ( !mpTabScroll )
- {
- mpTabScroll =
- new wxScrollBar( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSB_HORIZONTAL );
-
- mpHorizScroll =
- new wxScrollBar( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSB_HORIZONTAL );
- if (!mNoVertScroll) // Vertical Scroll (Original)
- mpVertScroll = new wxScrollBar( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxSB_VERTICAL );
- }
-
- {
- int units = GetWholeTabRowLen() / 20;
-
- mpTabScroll->SetScrollbar( 0, 1, units, 1, false );
- }
-
- // resetup position of the active tab
-
- int thumbLen = 16; // FOR NOW:: hardcoded
-
- int width, height;
- GetClientSize( &width, &height );
-
- mTitleHeight = thumbLen;
-
- int curX = mHorizGap + BORDER_SZ;
- int curY = mVertGap + BORDER_SZ;
-
- int xSize;
- if (!mNoVertScroll) // Vertical Scroll (Original)
- xSize = width - mHorizGap*2 - BORDER_SZ*2 - thumbLen;
- else
- xSize = width - mHorizGap*2 - BORDER_SZ*2;
-
- int ySize = height - mVertGap*2 - BORDER_SZ*2 - mTitleHeight;
-
- SizeTabs( curX, curY, xSize, ySize, andRepaint );
-
- // setup title bar LINES's horizontal scroll bar
-
- curY = height - mVertGap - BORDER_SZ - thumbLen;
-
- mpTabScroll->SetSize( curX, curY, thumbLen*2, thumbLen );
-
- // setup view's HORIZONTAL scroll bar
- curX += thumbLen*2;
-
- mTitleRowStart = curX;
- mFirstTitleGap = curX + mCurentRowOfs + mTabTrianGap;
-
- mTitleRowLen = wxMin( mAdjustableTitleRowLen,
- width - mHorizGap - BORDER_SZ - thumbLen*4 - curX );
-
- curX += mTitleRowLen;
-
- if (!mNoVertScroll) // Vertical Scroll (Original)
- mpHorizScroll->SetSize( curX, curY,width - curX - mHorizGap - BORDER_SZ - thumbLen, thumbLen );
- else
- mpHorizScroll->SetSize( curX, curY,width - curX - mHorizGap - BORDER_SZ-4, thumbLen );
-
- // setup view's VERTICAL scroll bar
- if (!mNoVertScroll) // Vertical Scroll (Original)
- {
- curX = width - mHorizGap - BORDER_SZ - thumbLen;
- curY = mVertGap + BORDER_SZ;
- mpVertScroll->SetSize( curX, curY, thumbLen,height - curY - mVertGap - BORDER_SZ - thumbLen);
- }
- // layout tab title bars
-
- mLayoutType = wxTITLE_IMG_AND_TEXT;
-
- wxObjectList::compatibility_iterator pNode = mTabs.GetFirst();
-
- while( pNode )
- {
- twTabInfo& tab = *((twTabInfo*)(pNode->GetData()));
-
- wxWindowDC dc(this);
-
- long w,h;
-
- // set select default font of the window into it's device context
- //dc.SetFont( GetLabelingFont() );
- dc.GetTextExtent(tab.mText, &w, &h );
-
- tab.mDims.x = w + tab.ImageToTxtGap(mImageTextGap) +
- tab.ImgWidth() + mTitleHorizGap*2;
-
- tab.mDims.y = mTitleHeight;
-
- pNode = pNode->GetNext();
- }
-
- // disable title-bar scroller if there's nowhere to scroll to
-
- mpTabScroll->Enable( mTitleRowLen < GetWholeTabRowLen() || mCurentRowOfs < 0 );
-}
-
-//---------------------------------------------------------------------------
-// event handlers
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnPaint( wxPaintEvent& WXUNUSED(event) )
-{
- wxPaintDC dc(this);
- DrawDecorations( dc );
-}
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnSize ( wxSizeEvent& event )
-{
- wxTabbedWindow::OnSize(event);
-}
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnLButtonDown( wxMouseEvent& event )
-{
- if ( mCursorChanged )
- {
- mIsDragged = true;
- mDagOrigin = event.m_x;
-
- mOriginalTitleRowLen = mAdjustableTitleRowLen;
-
- CaptureMouse();
- }
- else
- {
- wxTabbedWindow::OnLButtonDown( event );
- }
-} // wxPagedWindow::OnLButtonDown()
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnLButtonUp( wxMouseEvent& WXUNUSED(event) )
-{
- if ( mIsDragged )
- {
- mIsDragged = false;
- mCursorChanged = false;
- SetCursor( mNormalCursor );
-
- ReleaseMouse();
- }
-} // wxPagedWindow::OnLButtonUp()
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnMouseMove( wxMouseEvent& event )
-{
- int width, height;
- GetClientSize( &width, &height );
-
- if ( !mIsDragged )
- {
- int y = height - mVertGap - BORDER_SZ - mTitleHeight;
- int x = mTitleRowStart + mTitleRowLen - 6;
-
- if ( event.m_x >= x && event.m_y >= y &&
- event.m_x < x + 6 &&
- event.m_y < y + mTitleHeight
- )
- {
- if ( !mCursorChanged )
- {
- SetCursor( mResizeCursor );
-
- mCursorChanged = true;
- }
- }
- else
- if ( mCursorChanged )
- {
- SetCursor( mNormalCursor );
-
- mCursorChanged = false;
- }
- }
- else
- {
- if ( mIsDragged )
- {
- mAdjustableTitleRowLen = mOriginalTitleRowLen + ( event.m_x - mDagOrigin );
-
- // FOR NOW:: fixed
- if ( mAdjustableTitleRowLen < 6 ) mAdjustableTitleRowLen = 6;
-
- wxWindowDC dc(this);
- DrawDecorations( dc );
-
- RecalcLayout(false);
-
- //Refresh();
- }
- }
-} // wxPagedWindow::OnMouseMove()
-
-//---------------------------------------------------------------------------
-void wxPagedWindow::OnScroll( wxScrollEvent& event )
-{
- wxScrollBar* pSender = (wxScrollBar*)event.GetEventObject();
- // wxMessageBox("wxPagedWindow::OnScroll","-I->");
- if ( pSender == mpTabScroll )
- {
-
- int maxUnits = GetWholeTabRowLen() / 20;
-
- mCurentRowOfs = -event.GetPosition()*maxUnits;
-
- mFirstTitleGap = mTitleRowStart + mCurentRowOfs + mTabTrianGap;
-
- // let' it automatically disable itself if it's time
- mpTabScroll->Enable( mTitleRowLen < GetWholeTabRowLen() || mCurentRowOfs < 0 );
-
- // repaint title bars
- wxWindowDC dc(this);
- DrawDecorations( dc );
- }
- else
- {
- if ( !mScrollEventInProgress )
- {
- mScrollEventInProgress = true;
-
- GetActiveTab()->GetEventHandler()->ProcessEvent( event );
- }
- else
- {
- // event bounced back to us, from here we
- // know that it has traveled the loop - thus it's processed!
-
- mScrollEventInProgress = false;
- }
- }
-} // wxPagedWindow::OnScroll()
-//---------------------------------------------------------------------------
-