Files
libreoffice/svtools/source/control/headbar.cxx
2002-09-13 11:35:49 +00:00

1698 lines
50 KiB
C++

/*************************************************************************
*
* $RCSfile: headbar.cxx,v $
*
* $Revision: 1.4 $
*
* last change: $Author: pb $ $Date: 2002-09-13 12:35:49 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#define _SV_HEADBAR_CXX
#ifndef _HEADBAR_HXX
#include <headbar.hxx>
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef _TOOLS_LIST_HXX
#include <tools/list.hxx>
#endif
#ifndef _VCL_APP_HXX
#include <vcl/svapp.hxx>
#endif
#ifndef _VCL_HELP_HXX
#include <vcl/help.hxx>
#endif
#ifndef _VCL_IMAGE_HXX
#include <vcl/image.hxx>
#endif
#ifndef _DRAFTS_COM_SUN_STAR_ACCESSIBILITY_XACCESSIBLE_HPP_
#include <drafts/com/sun/star/accessibility/XAccessible.hpp>
#endif
// =======================================================================
struct ImplHeadItem
{
USHORT mnId;
HeaderBarItemBits mnBits;
long mnSize;
ULONG mnHelpId;
Image maImage;
XubString maOutText;
XubString maText;
XubString maHelpText;
void* mpUserData;
};
DECLARE_LIST( ImplHeadItemList, ImplHeadItem* );
// =======================================================================
#define HEAD_ARROWSIZE1 4
#define HEAD_ARROWSIZE2 7
#define HEADERBAR_TEXTOFF 2
#define HEADERBAR_ARROWOFF 5
#define HEADERBAR_SPLITOFF 3
#define HEADERBAR_DRAGOFF 4
#define HEADERBAR_DRAGOUTOFF 15
#define HEAD_HITTEST_ITEM ((USHORT)0x0001)
#define HEAD_HITTEST_DIVIDER ((USHORT)0x0002)
// =======================================================================
void HeaderBar::ImplInit( WinBits nWinStyle )
{
mpItemList = new ImplHeadItemList;
mnBorderOff1 = 0;
mnBorderOff2 = 0;
mnOffset = 0;
mnDX = 0;
mnDY = 0;
mnDragSize = 0;
mnStartPos = 0;
mnDragPos = 0;
mnMouseOff = 0;
mnCurItemId = 0;
mnItemDragPos = HEADERBAR_ITEM_NOTFOUND;
mbDrag = FALSE;
mbItemDrag = FALSE;
mbOutDrag = FALSE;
mbItemMode = FALSE;
// StyleBits auswerten
if ( nWinStyle & WB_DRAG )
mbDragable = TRUE;
else
mbDragable = FALSE;
if ( nWinStyle & WB_BUTTONSTYLE )
mbButtonStyle = TRUE;
else
mbButtonStyle = FALSE;
if ( nWinStyle & WB_BORDER )
{
mnBorderOff1 = 1;
mnBorderOff2 = 1;
}
else
{
if ( nWinStyle & WB_BOTTOMBORDER )
mnBorderOff2 = 1;
}
ImplInitSettings( TRUE, TRUE, TRUE );
}
// -----------------------------------------------------------------------
HeaderBar::HeaderBar( Window* pParent, WinBits nWinStyle ) :
Window( pParent, nWinStyle & WB_3DLOOK )
{
ImplInit( nWinStyle );
SetSizePixel( CalcWindowSizePixel() );
}
// -----------------------------------------------------------------------
HeaderBar::HeaderBar( Window* pParent, const ResId& rResId ) :
Window( pParent, rResId )
{
ImplInit( rResId.aWinBits );
}
// -----------------------------------------------------------------------
HeaderBar::~HeaderBar()
{
// Alle Items loeschen
ImplHeadItem* pItem = mpItemList->First();
while ( pItem )
{
delete pItem;
pItem = mpItemList->Next();
}
delete mpItemList;
}
// -----------------------------------------------------------------------
void HeaderBar::ImplInitSettings( BOOL bFont,
BOOL bForeground, BOOL bBackground )
{
const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings();
if ( bFont )
{
Font aFont;
aFont = rStyleSettings.GetToolFont();
if ( IsControlFont() )
aFont.Merge( GetControlFont() );
SetZoomedPointFont( aFont );
}
if ( bForeground || bFont )
{
Color aColor;
if ( IsControlForeground() )
aColor = GetControlForeground();
else
aColor = rStyleSettings.GetButtonTextColor();
SetTextColor( aColor );
SetTextFillColor();
}
if ( bBackground )
{
Color aColor;
if ( IsControlBackground() )
aColor = GetControlBackground();
else
aColor = rStyleSettings.GetFaceColor();
SetBackground( aColor );
}
}
// -----------------------------------------------------------------------
long HeaderBar::ImplGetItemPos( USHORT nPos ) const
{
long nX = -mnOffset;
for ( USHORT i = 0; i < nPos; i++ )
nX += mpItemList->GetObject( i )->mnSize;
return nX;
}
// -----------------------------------------------------------------------
Rectangle HeaderBar::ImplGetItemRect( USHORT nPos ) const
{
Rectangle aRect( ImplGetItemPos( nPos ), 0, 0, mnDY-1 );
aRect.Right() = aRect.Left() + mpItemList->GetObject( nPos )->mnSize - 1;
// Gegen Ueberlauf auf einigen Systemen testen
if ( aRect.Right() > 16000 )
aRect.Right() = 16000;
return aRect;
}
// -----------------------------------------------------------------------
USHORT HeaderBar::ImplHitTest( const Point& rPos,
long& nMouseOff, USHORT& nPos ) const
{
ImplHeadItem* pItem;
USHORT nCount = (USHORT)mpItemList->Count();
BOOL bLastFixed = TRUE;
long nX = -mnOffset;
for ( USHORT i = 0; i < nCount; i++ )
{
pItem = mpItemList->GetObject( i );
if ( rPos.X() < (nX+pItem->mnSize) )
{
USHORT nMode;
if ( !bLastFixed && (rPos.X() < (nX+HEADERBAR_SPLITOFF)) )
{
nMode = HEAD_HITTEST_DIVIDER;
nPos = i-1;
nMouseOff = rPos.X()-nX+1;
}
else
{
nPos = i;
if ( !(pItem->mnBits & HIB_FIXED) && (rPos.X() >= (nX+pItem->mnSize-HEADERBAR_SPLITOFF)) )
{
nMode = HEAD_HITTEST_DIVIDER;
nMouseOff = rPos.X()-(nX+pItem->mnSize);
}
else
{
nMode = HEAD_HITTEST_ITEM;
nMouseOff = rPos.X()-nX;
}
}
return nMode;
}
if ( pItem->mnBits & HIB_FIXED )
bLastFixed = TRUE;
else
bLastFixed = FALSE;
nX += pItem->mnSize;
}
if ( !bLastFixed )
{
pItem = mpItemList->GetObject( nCount-1 );
if ( (pItem->mnSize < 4) && (rPos.X() < (nX+HEADERBAR_SPLITOFF)) )
{
nPos = nCount-1;
nMouseOff = rPos.X()-nX+1;
return HEAD_HITTEST_DIVIDER;
}
}
return 0;
}
// -----------------------------------------------------------------------
void HeaderBar::ImplInvertDrag( USHORT nStartPos, USHORT nEndPos )
{
Rectangle aRect1 = ImplGetItemRect( nStartPos );
Rectangle aRect2 = ImplGetItemRect( nEndPos );
Point aStartPos = aRect1.Center();
Point aEndPos = aStartPos;
Rectangle aStartRect( aStartPos.X()-2, aStartPos.Y()-2,
aStartPos.X()+2, aStartPos.Y()+2 );
if ( nEndPos > nStartPos )
{
aStartPos.X() += 3;
aEndPos.X() = aRect2.Right()-6;
}
else
{
aStartPos.X() -= 3;
aEndPos.X() = aRect2.Left()+6;
}
SetRasterOp( ROP_INVERT );
DrawRect( aStartRect );
DrawLine( aStartPos, aEndPos );
if ( nEndPos > nStartPos )
{
DrawLine( Point( aEndPos.X()+1, aEndPos.Y()-3 ),
Point( aEndPos.X()+1, aEndPos.Y()+3 ) );
DrawLine( Point( aEndPos.X()+2, aEndPos.Y()-2 ),
Point( aEndPos.X()+2, aEndPos.Y()+2 ) );
DrawLine( Point( aEndPos.X()+3, aEndPos.Y()-1 ),
Point( aEndPos.X()+3, aEndPos.Y()+1 ) );
DrawPixel( Point( aEndPos.X()+4, aEndPos.Y() ) );
}
else
{
DrawLine( Point( aEndPos.X()-1, aEndPos.Y()-3 ),
Point( aEndPos.X()-1, aEndPos.Y()+3 ) );
DrawLine( Point( aEndPos.X()-2, aEndPos.Y()-2 ),
Point( aEndPos.X()-2, aEndPos.Y()+2 ) );
DrawLine( Point( aEndPos.X()-3, aEndPos.Y()-1 ),
Point( aEndPos.X()-3, aEndPos.Y()+1 ) );
DrawPixel( Point( aEndPos.X()-4, aEndPos.Y() ) );
}
SetRasterOp( ROP_OVERPAINT );
}
// -----------------------------------------------------------------------
void HeaderBar::ImplDrawItem( OutputDevice* pDev,
USHORT nPos, BOOL bHigh, BOOL bDrag,
const Rectangle& rItemRect,
const Rectangle* pRect,
ULONG nFlags )
{
Rectangle aRect = rItemRect;
// Wenn kein Platz, dann brauchen wir auch nichts ausgeben
if ( aRect.GetWidth() <= 1 )
return;
// Feststellen, ob Rectangle ueberhaupt sichtbar
if ( pRect )
{
if ( aRect.Right() < pRect->Left() )
return;
else if ( aRect.Left() > pRect->Right() )
return;
}
else
{
if ( aRect.Right() < 0 )
return;
else if ( aRect.Left() > mnDX )
return;
}
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
HeaderBarItemBits nBits = pItem->mnBits;
const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings();
// Border muss nicht gemalt werden
aRect.Top() += mnBorderOff1;
aRect.Bottom() -= mnBorderOff2;
// Hintergrund loeschen
if ( !pRect || bDrag )
{
if ( bDrag )
{
pDev->SetLineColor();
pDev->SetFillColor( rStyleSettings.GetCheckedColor() );
pDev->DrawRect( aRect );
}
else
pDev->DrawWallpaper( aRect, GetBackground() );
}
// Trennlinie malen
pDev->SetLineColor( rStyleSettings.GetDarkShadowColor() );
pDev->DrawLine( Point( aRect.Right(), aRect.Top() ),
Point( aRect.Right(), aRect.Bottom() ) );
// ButtonStyle malen
if ( mbButtonStyle && !(nBits & HIB_FLAT) )
{
if ( aRect.GetWidth() >= 2 )
{
if ( bHigh )
pDev->SetLineColor( rStyleSettings.GetShadowColor() );
else
pDev->SetLineColor( rStyleSettings.GetLightColor() );
pDev->DrawLine( aRect.TopLeft(), Point( aRect.Left(), aRect.Bottom() ) );
pDev->DrawLine( aRect.TopLeft(), Point( aRect.Right()-1, aRect.Top() ) );
if ( !bHigh )
{
pDev->SetLineColor( rStyleSettings.GetShadowColor() );
pDev->DrawLine( Point( aRect.Right()-1, aRect.Top()+1 ),
Point( aRect.Right()-1, aRect.Bottom() ) );
pDev->DrawLine( Point( aRect.Left()+1, aRect.Bottom() ),
Point( aRect.Right()-1, aRect.Bottom() ) );
}
}
aRect.Left()++;
aRect.Top()++;
aRect.Right()--;
aRect.Bottom()--;
// Wenn selektiert, verschiebt sich das Rechteck um 1 Pixel
if ( bHigh )
aRect.Move( 1, 1 );
}
// Wenn kein Platz, dann brauchen wir auch nichts ausgeben
if ( aRect.GetWidth() < 1 )
return;
// Positionen und Groessen berechnen und Inhalt ausgeben
pItem->maOutText = pItem->maText;
Size aImageSize = pItem->maImage.GetSizePixel();
Size aTxtSize( pDev->GetTextWidth( pItem->maOutText ), 0 );
if ( pItem->maOutText.Len() )
aTxtSize.Height() = pDev->GetTextHeight();
long nArrowWidth = 0;
if ( nBits & (HIB_UPARROW | HIB_DOWNARROW) )
nArrowWidth = HEAD_ARROWSIZE2+HEADERBAR_ARROWOFF;
// Wenn kein Platz fuer Image, dann nicht ausgeben
long nTestHeight = aImageSize.Height();
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nTestHeight += aTxtSize.Height();
if ( (aImageSize.Width() > aRect.GetWidth()) || (nTestHeight > aRect.GetHeight()) )
{
aImageSize.Width() = 0;
aImageSize.Height() = 0;
}
// Text auf entsprechende Laenge kuerzen
BOOL bLeftText = FALSE;
long nMaxTxtWidth = aRect.GetWidth()-(HEADERBAR_TEXTOFF*2)-nArrowWidth;
if ( nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE) )
nMaxTxtWidth -= aImageSize.Width();
long nTxtWidth = aTxtSize.Width();
if ( nTxtWidth > nMaxTxtWidth )
{
bLeftText = TRUE;
// 3 == Len of "..."
pItem->maOutText.AppendAscii( "..." );
do
{
pItem->maOutText.Erase( pItem->maOutText.Len()-3-1, 1 );
nTxtWidth = pDev->GetTextWidth( pItem->maOutText );
}
while ( (nTxtWidth > nMaxTxtWidth) && (pItem->maOutText.Len() > 3) );
if ( pItem->maOutText.Len() == 3 )
{
nTxtWidth = 0;
pItem->maOutText.Erase();
}
}
// Text/Imageposition berechnen
long nTxtPos;
if ( !bLeftText && (nBits & HIB_RIGHT) )
{
nTxtPos = aRect.Right()-nTxtWidth-HEADERBAR_TEXTOFF;
if ( nBits & HIB_RIGHTIMAGE )
nTxtPos -= aImageSize.Width();
}
else if ( !bLeftText && (nBits & HIB_CENTER) )
{
long nTempWidth = nTxtWidth;
if ( nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE) )
nTempWidth += aImageSize.Width();
nTxtPos = aRect.Left()+(aRect.GetWidth()-nTempWidth)/2;
if ( nBits & HIB_LEFTIMAGE )
nTxtPos += aImageSize.Width();
if ( nArrowWidth )
{
if ( nTxtPos+nTxtWidth+nArrowWidth >= aRect.Right() )
{
nTxtPos = aRect.Left()+HEADERBAR_TEXTOFF;
if ( nBits & HIB_LEFTIMAGE )
nTxtPos += aImageSize.Width();
}
}
}
else
{
nTxtPos = aRect.Left()+HEADERBAR_TEXTOFF;
if ( nBits & HIB_LEFTIMAGE )
nTxtPos += aImageSize.Width();
if ( nBits & HIB_RIGHT )
nTxtPos += nArrowWidth;
}
// TextPosition berechnen
long nTxtPosY;
if ( pItem->maOutText.Len() || (nArrowWidth && aTxtSize.Height()) )
{
if ( nBits & HIB_TOP )
{
nTxtPosY = aRect.Top();
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nTxtPosY += aImageSize.Height();
}
else if ( nBits & HIB_BOTTOM )
nTxtPosY = aRect.Bottom()-aTxtSize.Height();
else
{
long nTempHeight = aTxtSize.Height();
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nTempHeight += aImageSize.Height();
nTxtPosY = aRect.Top()+((aRect.GetHeight()-nTempHeight)/2);
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nTxtPosY += aImageSize.Height();
}
}
// Text ausgebeben
if ( pItem->maOutText.Len() )
{
if ( IsEnabled() )
pDev->DrawText( Point( nTxtPos, nTxtPosY ), pItem->maOutText );
else
pDev->DrawCtrlText( Point( nTxtPos, nTxtPosY ), pItem->maOutText, 0, STRING_LEN, TEXT_DRAW_DISABLE );
}
// Wenn Image vorhanden, Position berechnen und ausgeben
long nImagePosY;
if ( aImageSize.Width() && aImageSize.Height() )
{
long nImagePos = nTxtPos;
if ( nBits & HIB_LEFTIMAGE )
{
nImagePos -= aImageSize.Width();
if ( nBits & HIB_RIGHT )
nImagePos -= nArrowWidth;
}
else if ( nBits & HIB_RIGHTIMAGE )
{
nImagePos += nTxtWidth;
if ( !(nBits & HIB_RIGHT) )
nImagePos += nArrowWidth;
}
else
{
if ( nBits & HIB_RIGHT )
nImagePos = aRect.Right()-aImageSize.Width();
else if ( nBits & HIB_CENTER )
nImagePos = aRect.Left()+(aRect.GetWidth()-aImageSize.Width())/2;
else
nImagePos = aRect.Left()+HEADERBAR_TEXTOFF;
}
if ( nBits & HIB_TOP )
nImagePosY = aRect.Top();
else if ( nBits & HIB_BOTTOM )
{
nImagePosY = aRect.Bottom()-aImageSize.Height();
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nImagePosY -= aTxtSize.Height();
}
else
{
long nTempHeight = aImageSize.Height();
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) )
nTempHeight += aTxtSize.Height();
nImagePosY = aRect.Top()+((aRect.GetHeight()-nTempHeight)/2);
}
if ( nImagePos+aImageSize.Width() <= aRect.Right() )
{
USHORT nStyle = 0;
if ( !IsEnabled() )
nStyle |= IMAGE_DRAW_DISABLE;
pDev->DrawImage( Point( nImagePos, nImagePosY ), pItem->maImage, nStyle );
}
}
if ( nBits & (HIB_UPARROW | HIB_DOWNARROW) )
{
long nArrowX = nTxtPos;
if ( nBits & HIB_RIGHT )
nArrowX -= nArrowWidth;
else
nArrowX += nTxtWidth+HEADERBAR_ARROWOFF;
if ( !(nBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) && !pItem->maText.Len() )
{
if ( nBits & HIB_RIGHT )
nArrowX -= aImageSize.Width();
else
nArrowX += aImageSize.Width();
}
// Feststellen, ob Platz genug ist, das Item zu malen
BOOL bDraw = TRUE;
if ( nArrowX < aRect.Left()+HEADERBAR_TEXTOFF )
bDraw = FALSE;
else if ( nArrowX+HEAD_ARROWSIZE2 > aRect.Right() )
bDraw = FALSE;
if ( bDraw )
{
long nArrowY;
if ( aTxtSize.Height() )
nArrowY = nTxtPosY+(aTxtSize.Height()/2);
else if ( aImageSize.Width() && aImageSize.Height() )
nArrowY = nImagePosY+(aImageSize.Height()/2);
else
{
if ( nBits & HIB_TOP )
nArrowY = aRect.Top()+1;
else if ( nBits & HIB_BOTTOM )
nArrowY = aRect.Bottom()-HEAD_ARROWSIZE2-1;
else
nArrowY = aRect.Top()+((aRect.GetHeight()-HEAD_ARROWSIZE2)/2);;
}
nArrowY -= HEAD_ARROWSIZE1-1;
if ( nBits & HIB_DOWNARROW )
{
pDev->SetLineColor( rStyleSettings.GetLightColor() );
pDev->DrawLine( Point( nArrowX, nArrowY ),
Point( nArrowX+HEAD_ARROWSIZE2, nArrowY ) );
pDev->DrawLine( Point( nArrowX, nArrowY ),
Point( nArrowX+HEAD_ARROWSIZE1, nArrowY+HEAD_ARROWSIZE2 ) );
pDev->SetLineColor( rStyleSettings.GetShadowColor() );
pDev->DrawLine( Point( nArrowX+HEAD_ARROWSIZE1, nArrowY+HEAD_ARROWSIZE2 ),
Point( nArrowX+HEAD_ARROWSIZE2, nArrowY ) );
}
else
{
pDev->SetLineColor( rStyleSettings.GetLightColor() );
pDev->DrawLine( Point( nArrowX, nArrowY+HEAD_ARROWSIZE2 ),
Point( nArrowX+HEAD_ARROWSIZE1, nArrowY ) );
pDev->SetLineColor( rStyleSettings.GetShadowColor() );
pDev->DrawLine( Point( nArrowX, nArrowY+HEAD_ARROWSIZE2 ),
Point( nArrowX+HEAD_ARROWSIZE2, nArrowY+HEAD_ARROWSIZE2 ) );
pDev->DrawLine( Point( nArrowX+HEAD_ARROWSIZE2, nArrowY+HEAD_ARROWSIZE2 ),
Point( nArrowX+HEAD_ARROWSIZE1, nArrowY ) );
}
}
}
// Gegebenenfalls auch UserDraw aufrufen
if ( nBits & HIB_USERDRAW )
{
Region aRegion( aRect );
if ( pRect )
aRegion.Intersect( *pRect );
pDev->SetClipRegion( aRegion );
UserDrawEvent aODEvt( pDev, aRect, pItem->mnId );
UserDraw( aODEvt );
pDev->SetClipRegion();
}
}
// -----------------------------------------------------------------------
void HeaderBar::ImplDrawItem( USHORT nPos, BOOL bHigh, BOOL bDrag,
const Rectangle* pRect )
{
Rectangle aRect = ImplGetItemRect( nPos );
ImplDrawItem( this, nPos, bHigh, bDrag, aRect, pRect, 0 );
}
// -----------------------------------------------------------------------
void HeaderBar::ImplUpdate( USHORT nPos, BOOL bEnd, BOOL bDirect )
{
if ( IsVisible() && IsUpdateMode() )
{
if ( !bDirect )
{
Rectangle aRect;
USHORT nItemCount = (USHORT)(mpItemList->Count());
if ( nPos < nItemCount )
aRect = ImplGetItemRect( nPos );
else
{
aRect.Bottom() = mnDY-1;
if ( nItemCount )
aRect.Left() = ImplGetItemRect( nItemCount-1 ).Right();
}
if ( bEnd )
aRect.Right() = mnDX-1;
aRect.Top() += mnBorderOff1;
aRect.Bottom() -= mnBorderOff2;
Invalidate( aRect );
}
else
{
for ( USHORT i = nPos; i < mpItemList->Count(); i++ )
ImplDrawItem( i );
if ( bEnd )
{
Rectangle aRect = ImplGetItemRect( (USHORT)mpItemList->Count() );
aRect.Left() = aRect.Right();
aRect.Right() = mnDX-1;
if ( aRect.Left() < aRect.Right() )
{
aRect.Top() += mnBorderOff1;
aRect.Bottom() -= mnBorderOff2;
Erase( aRect );
}
}
}
}
}
// -----------------------------------------------------------------------
void HeaderBar::ImplStartDrag( const Point& rMousePos, BOOL bCommand )
{
USHORT nPos;
USHORT nHitTest = ImplHitTest( rMousePos, mnMouseOff, nPos );
if ( nHitTest )
{
mbDrag = FALSE;
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( nHitTest & HEAD_HITTEST_DIVIDER )
mbDrag = TRUE;
else
{
if ( ((pItem->mnBits & HIB_CLICKABLE) && !(pItem->mnBits & HIB_FLAT)) ||
(mbDragable && !(pItem->mnBits & HIB_FIXEDPOS)) )
{
mbItemMode = TRUE;
mbDrag = TRUE;
if ( bCommand )
{
if ( mbDragable )
mbItemDrag = TRUE;
else
{
mbItemMode = FALSE;
mbDrag = FALSE;
}
}
}
else
{
if ( !bCommand )
{
mnCurItemId = pItem->mnId;
Select();
mnCurItemId = 0;
}
}
}
if ( mbDrag )
{
mbOutDrag = FALSE;
mnCurItemId = pItem->mnId;
mnItemDragPos = nPos;
StartTracking();
mnStartPos = rMousePos.X()-mnMouseOff;
mnDragPos = mnStartPos;
StartDrag();
if ( mbItemMode )
ImplDrawItem( nPos, TRUE, mbItemDrag );
else
{
Rectangle aSizeRect( mnDragPos, 0, mnDragPos, mnDragSize+mnDY );
ShowTracking( aSizeRect, SHOWTRACK_SPLIT );
}
}
else
mnMouseOff = 0;
}
}
// -----------------------------------------------------------------------
void HeaderBar::ImplDrag( const Point& rMousePos )
{
BOOL bNewOutDrag;
USHORT nPos = GetItemPos( mnCurItemId );
mnDragPos = rMousePos.X()-mnMouseOff;
if ( mbItemMode )
{
Rectangle aItemRect = ImplGetItemRect( nPos );
if ( aItemRect.IsInside( rMousePos ) )
bNewOutDrag = FALSE;
else
bNewOutDrag = TRUE;
// Evt. ItemDrag anschalten
if ( bNewOutDrag && mbDragable && !mbItemDrag &&
!(mpItemList->GetObject(nPos)->mnBits & HIB_FIXEDPOS) )
{
if ( (rMousePos.Y() >= aItemRect.Top()) && (rMousePos.Y() <= aItemRect.Bottom()) )
{
mbItemDrag = TRUE;
ImplDrawItem( nPos, TRUE, mbItemDrag );
}
}
USHORT nOldItemDragPos = mnItemDragPos;
if ( mbItemDrag )
{
if ( (rMousePos.Y() < -HEADERBAR_DRAGOUTOFF) || (rMousePos.Y() > mnDY+HEADERBAR_DRAGOUTOFF) )
bNewOutDrag = TRUE;
else
bNewOutDrag = FALSE;
if ( bNewOutDrag )
mnItemDragPos = HEADERBAR_ITEM_NOTFOUND;
else
{
USHORT nTempId = GetItemId( Point( rMousePos.X(), 2 ) );
if ( nTempId )
mnItemDragPos = GetItemPos( nTempId );
else
{
if ( rMousePos.X() <= 0 )
mnItemDragPos = 0;
else
mnItemDragPos = GetItemCount()-1;
}
// Nicht verschiebbare Items aussparen
if ( mnItemDragPos < nPos )
{
while ( (mpItemList->GetObject(mnItemDragPos)->mnBits & HIB_FIXEDPOS) &&
(mnItemDragPos < nPos) )
mnItemDragPos++;
}
else if ( mnItemDragPos > nPos )
{
while ( (mpItemList->GetObject(mnItemDragPos)->mnBits & HIB_FIXEDPOS) &&
(mnItemDragPos > nPos) )
mnItemDragPos--;
}
}
if ( (mnItemDragPos != nOldItemDragPos) &&
(nOldItemDragPos != nPos) &&
(nOldItemDragPos != HEADERBAR_ITEM_NOTFOUND) )
{
ImplInvertDrag( nPos, nOldItemDragPos );
ImplDrawItem( nOldItemDragPos );
}
}
if ( bNewOutDrag != mbOutDrag )
ImplDrawItem( nPos, !bNewOutDrag, mbItemDrag );
if ( mbItemDrag )
{
if ( (mnItemDragPos != nOldItemDragPos) &&
(mnItemDragPos != nPos) &&
(mnItemDragPos != HEADERBAR_ITEM_NOTFOUND) )
{
ImplDrawItem( mnItemDragPos, FALSE, TRUE );
ImplInvertDrag( nPos, mnItemDragPos );
}
}
mbOutDrag = bNewOutDrag;
}
else
{
Rectangle aItemRect = ImplGetItemRect( nPos );
if ( mnDragPos < aItemRect.Left() )
mnDragPos = aItemRect.Left();
if ( (mnDragPos < 0) || (mnDragPos > mnDX-1) )
HideTracking();
else
{
Rectangle aSizeRect( mnDragPos, 0, mnDragPos, mnDragSize+mnDY );
ShowTracking( aSizeRect, SHOWTRACK_SPLIT );
}
}
Drag();
}
// -----------------------------------------------------------------------
void HeaderBar::ImplEndDrag( BOOL bCancel )
{
HideTracking();
if ( bCancel || mbOutDrag )
{
if ( mbItemMode && (!mbOutDrag || mbItemDrag) )
{
USHORT nPos = GetItemPos( mnCurItemId );
ImplDrawItem( nPos );
}
mnCurItemId = 0;
}
else
{
USHORT nPos = GetItemPos( mnCurItemId );
if ( mbItemMode )
{
if ( mbItemDrag )
{
Pointer aPointer( POINTER_ARROW );
SetPointer( aPointer );
if ( (mnItemDragPos != nPos) &&
(mnItemDragPos != HEADERBAR_ITEM_NOTFOUND) )
{
ImplInvertDrag( nPos, mnItemDragPos );
MoveItem( mnCurItemId, mnItemDragPos );
}
else
ImplDrawItem( nPos );
}
else
{
Select();
ImplUpdate( nPos );
}
}
else
{
long nDelta = mnDragPos - mnStartPos;
if ( nDelta )
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
pItem->mnSize += nDelta;
ImplUpdate( nPos, TRUE );
}
}
}
mbDrag = FALSE;
EndDrag();
mnCurItemId = 0;
mnItemDragPos = HEADERBAR_ITEM_NOTFOUND;
mbOutDrag = FALSE;
mbItemMode = FALSE;
mbItemDrag = FALSE;
}
// -----------------------------------------------------------------------
void HeaderBar::MouseButtonDown( const MouseEvent& rMEvt )
{
if ( rMEvt.IsLeft() )
{
if ( rMEvt.GetClicks() == 2 )
{
long nTemp;
USHORT nPos;
USHORT nHitTest = ImplHitTest( rMEvt.GetPosPixel(), nTemp, nPos );
if ( nHitTest )
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( nHitTest & HEAD_HITTEST_DIVIDER )
mbItemMode = FALSE;
else
mbItemMode = TRUE;
mnCurItemId = pItem->mnId;
DoubleClick();
mbItemMode = FALSE;
mnCurItemId = 0;
}
}
else
ImplStartDrag( rMEvt.GetPosPixel(), FALSE );
}
}
// -----------------------------------------------------------------------
void HeaderBar::MouseMove( const MouseEvent& rMEvt )
{
long nTemp1;
USHORT nTemp2;
PointerStyle eStyle = POINTER_ARROW;
USHORT nHitTest = ImplHitTest( rMEvt.GetPosPixel(), nTemp1, nTemp2 );
if ( nHitTest & HEAD_HITTEST_DIVIDER )
eStyle = POINTER_HSIZEBAR;
Pointer aPtr( eStyle );
SetPointer( aPtr );
}
// -----------------------------------------------------------------------
void HeaderBar::Tracking( const TrackingEvent& rTEvt )
{
Point aMousePos = rTEvt.GetMouseEvent().GetPosPixel();
if ( rTEvt.IsTrackingEnded() )
ImplEndDrag( rTEvt.IsTrackingCanceled() );
else
ImplDrag( aMousePos );
}
// -----------------------------------------------------------------------
void HeaderBar::Paint( const Rectangle& rRect )
{
if ( mnBorderOff1 || mnBorderOff2 )
{
SetLineColor( GetSettings().GetStyleSettings().GetDarkShadowColor() );
if ( mnBorderOff1 )
DrawLine( Point( 0, 0 ), Point( mnDX-1, 0 ) );
if ( mnBorderOff2 )
DrawLine( Point( 0, mnDY-1 ), Point( mnDX-1, mnDY-1 ) );
}
USHORT nCurItemPos;
if ( mbDrag )
nCurItemPos = GetItemPos( mnCurItemId );
else
nCurItemPos = HEADERBAR_ITEM_NOTFOUND;
USHORT nItemCount = (USHORT)mpItemList->Count();
for ( USHORT i = 0; i < nItemCount; i++ )
ImplDrawItem( i, (i == nCurItemPos) ? TRUE : FALSE, FALSE, &rRect );
}
// -----------------------------------------------------------------------
void HeaderBar::Draw( OutputDevice* pDev, const Point& rPos, const Size& rSize,
ULONG nFlags )
{
Point aPos = pDev->LogicToPixel( rPos );
Size aSize = pDev->LogicToPixel( rSize );
Rectangle aRect( aPos, aSize );
Font aFont = GetDrawPixelFont( pDev );
pDev->Push();
pDev->SetMapMode();
pDev->SetFont( aFont );
if ( nFlags & WINDOW_DRAW_MONO )
pDev->SetTextColor( Color( COL_BLACK ) );
else
pDev->SetTextColor( GetTextColor() );
pDev->SetTextFillColor();
if ( !(nFlags & WINDOW_DRAW_NOBACKGROUND) )
{
pDev->DrawWallpaper( aRect, GetBackground() );
if ( mnBorderOff1 || mnBorderOff2 )
{
pDev->SetLineColor( GetSettings().GetStyleSettings().GetDarkShadowColor() );
if ( mnBorderOff1 )
pDev->DrawLine( aRect.TopLeft(), Point( aRect.Right(), aRect.Top() ) );
if ( mnBorderOff2 )
pDev->DrawLine( Point( aRect.Left(), aRect.Bottom() ), Point( aRect.Right(), aRect.Bottom() ) );
}
}
Rectangle aItemRect( aRect );
// aItemRect.Bottom()--;
USHORT nItemCount = (USHORT)mpItemList->Count();
for ( USHORT i = 0; i < nItemCount; i++ )
{
aItemRect.Left() = aRect.Left()+ImplGetItemPos( i );
aItemRect.Right() = aItemRect.Left() + mpItemList->GetObject( i )->mnSize - 1;
// Gegen Ueberlauf auf einigen Systemen testen
if ( aItemRect.Right() > 16000 )
aItemRect.Right() = 16000;
Region aRegion( aRect );
pDev->SetClipRegion( aRegion );
ImplDrawItem( pDev, i, FALSE, FALSE, aItemRect, &aRect, nFlags );
pDev->SetClipRegion();
}
pDev->Pop();
}
// -----------------------------------------------------------------------
void HeaderBar::Resize()
{
Size aSize = GetOutputSizePixel();
if ( IsVisible() && (mnDY != aSize.Height()) )
Invalidate();
mnDX = aSize.Width();
mnDY = aSize.Height();
}
// -----------------------------------------------------------------------
void HeaderBar::Command( const CommandEvent& rCEvt )
{
if ( rCEvt.IsMouseEvent() && (rCEvt.GetCommand() == COMMAND_STARTDRAG) && !mbDrag )
{
ImplStartDrag( rCEvt.GetMousePosPixel(), TRUE );
return;
}
Window::Command( rCEvt );
}
// -----------------------------------------------------------------------
void HeaderBar::RequestHelp( const HelpEvent& rHEvt )
{
USHORT nItemId = GetItemId( ScreenToOutputPixel( rHEvt.GetMousePosPixel() ) );
if ( nItemId )
{
if ( rHEvt.GetMode() & (HELPMODE_QUICK | HELPMODE_BALLOON) )
{
Rectangle aItemRect = GetItemRect( nItemId );
Point aPt = OutputToScreenPixel( aItemRect.TopLeft() );
aItemRect.Left() = aPt.X();
aItemRect.Top() = aPt.Y();
aPt = OutputToScreenPixel( aItemRect.BottomRight() );
aItemRect.Right() = aPt.X();
aItemRect.Bottom() = aPt.Y();
XubString aStr = GetHelpText( nItemId );
if ( !aStr.Len() || !(rHEvt.GetMode() & HELPMODE_BALLOON) )
{
ImplHeadItem* pItem = mpItemList->GetObject( GetItemPos( nItemId ) );
// Wir zeigen die Quick-Hilfe nur an, wenn Text nicht
// vollstaendig sichtbar, ansonsten zeigen wir den Hilfetext
// an, wenn das Item keinen Text besitzt
if ( pItem->maOutText != pItem->maText )
aStr = pItem->maText;
else if ( pItem->maText.Len() )
aStr.Erase();
}
if ( aStr.Len() )
{
if ( rHEvt.GetMode() & HELPMODE_BALLOON )
Help::ShowBalloon( this, aItemRect.Center(), aItemRect, aStr );
else
Help::ShowQuickHelp( this, aItemRect, aStr );
return;
}
}
else if ( rHEvt.GetMode() & HELPMODE_EXTENDED )
{
ULONG nHelpId = GetHelpId( nItemId );
if ( nHelpId )
{
// Wenn eine Hilfe existiert, dann ausloesen
Help* pHelp = Application::GetHelp();
if ( pHelp )
pHelp->Start( nHelpId, this );
return;
}
}
}
Window::RequestHelp( rHEvt );
}
// -----------------------------------------------------------------------
void HeaderBar::StateChanged( StateChangedType nType )
{
Window::StateChanged( nType );
if ( nType == STATE_CHANGE_ENABLE )
Invalidate();
else if ( (nType == STATE_CHANGE_ZOOM) ||
(nType == STATE_CHANGE_CONTROLFONT) )
{
ImplInitSettings( TRUE, FALSE, FALSE );
Invalidate();
}
else if ( nType == STATE_CHANGE_CONTROLFOREGROUND )
{
ImplInitSettings( FALSE, TRUE, FALSE );
Invalidate();
}
else if ( nType == STATE_CHANGE_CONTROLBACKGROUND )
{
ImplInitSettings( FALSE, FALSE, TRUE );
Invalidate();
}
}
// -----------------------------------------------------------------------
void HeaderBar::DataChanged( const DataChangedEvent& rDCEvt )
{
Window::DataChanged( rDCEvt );
if ( (rDCEvt.GetType() == DATACHANGED_FONTS) ||
(rDCEvt.GetType() == DATACHANGED_FONTSUBSTITUTION) ||
((rDCEvt.GetType() == DATACHANGED_SETTINGS) &&
(rDCEvt.GetFlags() & SETTINGS_STYLE)) )
{
ImplInitSettings( TRUE, TRUE, TRUE );
Invalidate();
}
}
// -----------------------------------------------------------------------
void HeaderBar::UserDraw( const UserDrawEvent& )
{
}
// -----------------------------------------------------------------------
void HeaderBar::StartDrag()
{
maStartDragHdl.Call( this );
}
// -----------------------------------------------------------------------
void HeaderBar::Drag()
{
maDragHdl.Call( this );
}
// -----------------------------------------------------------------------
void HeaderBar::EndDrag()
{
maEndDragHdl.Call( this );
}
// -----------------------------------------------------------------------
void HeaderBar::Select()
{
maSelectHdl.Call( this );
}
// -----------------------------------------------------------------------
void HeaderBar::DoubleClick()
{
maDoubleClickHdl.Call( this );
}
// -----------------------------------------------------------------------
void HeaderBar::InsertItem( USHORT nItemId, const Image& rImage,
long nSize, HeaderBarItemBits nBits, USHORT nPos )
{
DBG_ASSERT( nItemId, "HeaderBar::InsertItem(): ItemId == 0" );
DBG_ASSERT( GetItemPos( nItemId ) == HEADERBAR_ITEM_NOTFOUND,
"HeaderBar::InsertItem(): ItemId already exists" );
// Item anlegen und in die Liste einfuegen
ImplHeadItem* pItem = new ImplHeadItem;
pItem->mnId = nItemId;
pItem->mnBits = nBits;
pItem->mnSize = nSize;
pItem->maImage = rImage;
pItem->mpUserData = 0;
mpItemList->Insert( pItem, nPos );
// Ausgabe updaten
ImplUpdate( nPos, TRUE );
}
// -----------------------------------------------------------------------
void HeaderBar::InsertItem( USHORT nItemId, const XubString& rText,
long nSize, HeaderBarItemBits nBits, USHORT nPos )
{
DBG_ASSERT( nItemId, "HeaderBar::InsertItem(): ItemId == 0" );
DBG_ASSERT( GetItemPos( nItemId ) == HEADERBAR_ITEM_NOTFOUND,
"HeaderBar::InsertItem(): ItemId already exists" );
// Item anlegen und in die Liste einfuegen
ImplHeadItem* pItem = new ImplHeadItem;
pItem->mnId = nItemId;
pItem->mnBits = nBits;
pItem->mnSize = nSize;
pItem->mnHelpId = 0;
pItem->maText = rText;
pItem->mpUserData = 0;
mpItemList->Insert( pItem, nPos );
// Ausgabe updaten
ImplUpdate( nPos, TRUE );
}
// -----------------------------------------------------------------------
void HeaderBar::InsertItem( USHORT nItemId,
const Image& rImage, const XubString& rText,
long nSize, HeaderBarItemBits nBits,
USHORT nPos )
{
DBG_ASSERT( nItemId, "HeaderBar::InsertItem(): ItemId == 0" );
DBG_ASSERT( GetItemPos( nItemId ) == HEADERBAR_ITEM_NOTFOUND,
"HeaderBar::InsertItem(): ItemId already exists" );
// Item anlegen und in die Liste einfuegen
ImplHeadItem* pItem = new ImplHeadItem;
pItem->mnId = nItemId;
pItem->mnBits = nBits;
pItem->mnSize = nSize;
pItem->mnHelpId = 0;
pItem->maImage = rImage;
pItem->maText = rText;
pItem->mpUserData = 0;
mpItemList->Insert( pItem, nPos );
// Ausgabe updaten
ImplUpdate( nPos, TRUE );
}
// -----------------------------------------------------------------------
void HeaderBar::RemoveItem( USHORT nItemId )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
ImplHeadItem* pItem = mpItemList->Remove( nPos );
delete pItem;
ImplUpdate( nPos, TRUE );
}
}
// -----------------------------------------------------------------------
void HeaderBar::MoveItem( USHORT nItemId, USHORT nNewPos )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
if ( nPos != nNewPos )
{
ImplHeadItem* pItem = mpItemList->Remove( nPos );
if ( nNewPos < nPos )
nPos = nNewPos;
mpItemList->Insert( pItem, nNewPos );
ImplUpdate( nPos, TRUE );
}
}
}
// -----------------------------------------------------------------------
void HeaderBar::Clear()
{
// Alle Items loeschen
ImplHeadItem* pItem = mpItemList->First();
while ( pItem )
{
delete pItem;
pItem = mpItemList->Next();
}
mpItemList->Clear();
ImplUpdate( 0, TRUE );
}
// -----------------------------------------------------------------------
void HeaderBar::SetOffset( long nNewOffset )
{
// Hier erstmal neu zeichnen, damit mit alten Offset noch das
// richtige gemalt wird
//Update();
// Bereich verschieben
Rectangle aRect( 0, mnBorderOff1, mnDX-1, mnDY-mnBorderOff1-mnBorderOff2-1 );
long nDelta = mnOffset-nNewOffset;
mnOffset = nNewOffset;
Scroll( nDelta, 0, aRect );
}
// -----------------------------------------------------------------------
USHORT HeaderBar::GetItemCount() const
{
return (USHORT)mpItemList->Count();
}
// -----------------------------------------------------------------------
USHORT HeaderBar::GetItemPos( USHORT nItemId ) const
{
ImplHeadItem* pItem = mpItemList->First();
while ( pItem )
{
if ( pItem->mnId == nItemId )
return (USHORT)mpItemList->GetCurPos();
pItem = mpItemList->Next();
}
return HEADERBAR_ITEM_NOTFOUND;
}
// -----------------------------------------------------------------------
USHORT HeaderBar::GetItemId( USHORT nPos ) const
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( pItem )
return pItem->mnId;
else
return 0;
}
// -----------------------------------------------------------------------
USHORT HeaderBar::GetItemId( const Point& rPos ) const
{
USHORT nPos = 0;
while ( nPos < mpItemList->Count() )
{
if ( ImplGetItemRect( nPos ).IsInside( rPos ) )
return GetItemId( nPos );
nPos++;
}
return 0;
}
// -----------------------------------------------------------------------
Rectangle HeaderBar::GetItemRect( USHORT nItemId ) const
{
Rectangle aRect;
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
aRect = ImplGetItemRect( nPos );
return aRect;
}
// -----------------------------------------------------------------------
void HeaderBar::SetItemSize( USHORT nItemId, long nNewSize )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( pItem->mnSize != nNewSize )
{
pItem->mnSize = nNewSize;
ImplUpdate( nPos, TRUE );
}
}
}
// -----------------------------------------------------------------------
long HeaderBar::GetItemSize( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->mnSize;
else
return 0;
}
// -----------------------------------------------------------------------
void HeaderBar::SetItemBits( USHORT nItemId, HeaderBarItemBits nNewBits )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( pItem->mnBits != nNewBits )
{
pItem->mnBits = nNewBits;
ImplUpdate( nPos );
}
}
}
// -----------------------------------------------------------------------
HeaderBarItemBits HeaderBar::GetItemBits( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->mnBits;
else
return 0;
}
// -----------------------------------------------------------------------
void HeaderBar::SetItemData( USHORT nItemId, void* pNewData )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
mpItemList->GetObject( nPos )->mpUserData = pNewData;
ImplUpdate( nPos );
}
}
// -----------------------------------------------------------------------
void* HeaderBar::GetItemData( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->mpUserData;
else
return NULL;
}
// -----------------------------------------------------------------------
void HeaderBar::SetItemImage( USHORT nItemId, const Image& rImage )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
mpItemList->GetObject( nPos )->maImage = rImage;
ImplUpdate( nPos );
}
}
// -----------------------------------------------------------------------
Image HeaderBar::GetItemImage( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->maImage;
else
return Image();
}
// -----------------------------------------------------------------------
void HeaderBar::SetItemText( USHORT nItemId, const XubString& rText )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
mpItemList->GetObject( nPos )->maText = rText;
ImplUpdate( nPos );
}
}
// -----------------------------------------------------------------------
XubString HeaderBar::GetItemText( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->maText;
else
return String();
}
// -----------------------------------------------------------------------
void HeaderBar::SetHelpText( USHORT nItemId, const XubString& rText )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
mpItemList->GetObject( nPos )->maHelpText = rText;
}
// -----------------------------------------------------------------------
XubString HeaderBar::GetHelpText( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
{
ImplHeadItem* pItem = mpItemList->GetObject( nPos );
if ( !pItem->maHelpText.Len() && pItem->mnHelpId )
{
Help* pHelp = Application::GetHelp();
if ( pHelp )
pItem->maHelpText = pHelp->GetHelpText( pItem->mnHelpId, this );
}
return pItem->maHelpText;
}
else
return XubString();
}
// -----------------------------------------------------------------------
void HeaderBar::SetHelpId( USHORT nItemId, ULONG nHelpId )
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
mpItemList->GetObject( nPos )->mnHelpId = nHelpId;
}
// -----------------------------------------------------------------------
ULONG HeaderBar::GetHelpId( USHORT nItemId ) const
{
USHORT nPos = GetItemPos( nItemId );
if ( nPos != HEADERBAR_ITEM_NOTFOUND )
return mpItemList->GetObject( nPos )->mnHelpId;
else
return 0;
}
// -----------------------------------------------------------------------
Size HeaderBar::CalcWindowSizePixel() const
{
long nMaxImageSize = 0;
Size aSize( 0, GetTextHeight() );
ImplHeadItem* pItem = mpItemList->First();
while ( pItem )
{
// Image-Groessen beruecksichtigen
long nImageHeight = pItem->maImage.GetSizePixel().Height();
if ( !(pItem->mnBits & (HIB_LEFTIMAGE | HIB_RIGHTIMAGE)) && pItem->maText.Len() )
nImageHeight += aSize.Height();
if ( nImageHeight > nMaxImageSize )
nMaxImageSize = nImageHeight;
// Breite aufaddieren
aSize.Width() += pItem->mnSize;
pItem = mpItemList->Next();
}
if ( nMaxImageSize > aSize.Height() )
aSize.Height() = nMaxImageSize;
// Border aufaddieren
if ( mbButtonStyle )
aSize.Height() += 4;
else
aSize.Height() += 2;
aSize.Height() += mnBorderOff1+mnBorderOff2;
return aSize;
}
::com::sun::star::uno::Reference< ::drafts::com::sun::star::accessibility::XAccessible > HeaderBar::CreateAccessible()
{
if ( !mxAccessible.is() )
{
if ( maCreateAccessibleHdl.IsSet() )
maCreateAccessibleHdl.Call( this );
if ( !mxAccessible.is() )
mxAccessible = Window::CreateAccessible();
}
return mxAccessible;
}
void HeaderBar::SetAccessible( ::com::sun::star::uno::Reference< ::drafts::com::sun::star::accessibility::XAccessible > _xAccessible )
{
mxAccessible = _xAccessible;
}