Files
libreoffice/sw/source/core/text/blink.cxx
Jens-Heiner Rechtien bcb4593564 INTEGRATION: CWS writercorehandoff (1.4.1116); FILE MERGED
2005/09/13 14:26:21 tra 1.4.1116.2: RESYNC: (1.4-1.5); FILE MERGED
2005/07/19 06:05:51 fme 1.4.1116.1: #i50348# make SwDoc accessible via interfaces
2006-08-14 15:35:47 +00:00

207 lines
6.9 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: blink.cxx,v $
*
* $Revision: 1.6 $
*
* last change: $Author: hr $ $Date: 2006-08-14 16:35:47 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 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
*
************************************************************************/
#pragma hdrstop
#ifndef _DEBUG_HXX //autogen
#include <tools/debug.hxx>
#endif
#include "viewsh.hxx"
#include "rootfrm.hxx" // GetOleShell()
#include "txtfrm.hxx" // FindRootFrm()
#include "blink.hxx"
#include "porlin.hxx"
#include "porlay.hxx" // SwLineLayout
// Sichtbare Zeit:
#define BLINK_ON_TIME 2400L
// Nihct sichtbare Zeit:
#define BLINK_OFF_TIME 800L
/*************************************************************************
* pBlink zeigt auf die Instanz, bei der sich blinkende Portions anmelden
* muessen, ggf. muss pBlink erst per new SwBlink angelegt werden.
* Diese werden dann rhythmisch zum Repaint angeregt und koennen abfragen,
* ob sie zur Zeit sichtbar oder unsichtbar sein sollen ( IsVisible() ).
*************************************************************************/
SwBlink *pBlink = NULL;
// Liste von blinkenden Portions
SV_IMPL_OP_PTRARR_SORT( SwBlinkList, SwBlinkPortionPtr )
SwBlink::SwBlink()
{
bVisible = sal_True;
// Den Timer vorbereiten
aTimer.SetTimeout( BLINK_ON_TIME );
aTimer.SetTimeoutHdl( LINK(this, SwBlink, Blinker) );
}
SwBlink::~SwBlink( )
{
aTimer.Stop();
}
/*************************************************************************
* SwBlink::Blinker (Timerablauf):
* Sichtbar/unsichtbar-Flag toggeln.
* Repaint-Rechtecke der Blinkportions ermitteln und an ihren OleShells
* invalidieren.
*************************************************************************/
IMPL_LINK( SwBlink, Blinker, Timer *, pTimer )
{
bVisible = !bVisible;
if( bVisible )
aTimer.SetTimeout( BLINK_ON_TIME );
else
aTimer.SetTimeout( BLINK_OFF_TIME );
if( aList.Count() )
{
for( MSHORT nPos = 0; nPos < aList.Count(); )
{
const SwBlinkPortion* pTmp = aList[ nPos ];
if( pTmp->GetRootFrm() &&
((SwRootFrm*)pTmp->GetRootFrm())->GetCurrShell() )
{
++nPos;
Point aPos = pTmp->GetPos();
long nWidth, nHeight;
switch ( pTmp->GetDirection() )
{
case 900:
aPos.X() -= pTmp->GetPortion()->GetAscent();
aPos.Y() -= pTmp->GetPortion()->Width();
nWidth = pTmp->GetPortion()->SvLSize().Height();
nHeight = pTmp->GetPortion()->SvLSize().Width();
break;
case 1800:
aPos.Y() -= pTmp->GetPortion()->Height() -
pTmp->GetPortion()->GetAscent();
aPos.X() -= pTmp->GetPortion()->Width();
nWidth = pTmp->GetPortion()->SvLSize().Width();
nHeight = pTmp->GetPortion()->SvLSize().Height();
break;
case 2700:
aPos.X() -= pTmp->GetPortion()->Height() -
pTmp->GetPortion()->GetAscent();
nWidth = pTmp->GetPortion()->SvLSize().Height();
nHeight = pTmp->GetPortion()->SvLSize().Width();
break;
default:
aPos.Y() -= pTmp->GetPortion()->GetAscent();
nWidth = pTmp->GetPortion()->SvLSize().Width();
nHeight = pTmp->GetPortion()->SvLSize().Height();
}
Rectangle aRefresh( aPos, Size( nWidth, nHeight ) );
aRefresh.Right() += ( aRefresh.Bottom()- aRefresh.Top() ) / 8;
((SwRootFrm*)pTmp->GetRootFrm())
->GetCurrShell()->InvalidateWindows( aRefresh );
}
else // Portions ohne Shell koennen aus der Liste entfernt werden.
aList.Remove( nPos );
}
}
else // Wenn die Liste leer ist, kann der Timer gestoppt werden.
aTimer.Stop();
return sal_True;
}
void SwBlink::Insert( const Point& rPoint, const SwLinePortion* pPor,
const SwTxtFrm *pTxtFrm, USHORT nDir )
{
SwBlinkPortion *pBlinkPor = new SwBlinkPortion( pPor, nDir );
MSHORT nPos;
if( aList.Seek_Entry( pBlinkPor, &nPos ) )
{
aList[ nPos ]->SetPos( rPoint );
delete pBlinkPor;
}
else
{
pBlinkPor->SetPos( rPoint );
pBlinkPor->SetRootFrm( pTxtFrm->FindRootFrm() );
aList.Insert( pBlinkPor );
pTxtFrm->SetBlinkPor();
if( pPor->IsLayPortion() || pPor->IsParaPortion() )
((SwLineLayout*)pPor)->SetBlinking( sal_True );
if( !aTimer.IsActive() )
aTimer.Start();
}
}
void SwBlink::Replace( const SwLinePortion* pOld, const SwLinePortion* pNew )
{
// setting direction to 0 because direction does not matter
// for this operation
SwBlinkPortion aBlink( pOld, 0 );
MSHORT nPos;
if( aList.Seek_Entry( &aBlink, &nPos ) )
{
SwBlinkPortion* pTmp = new SwBlinkPortion( aList[ nPos ], pNew );
aList.Remove( nPos );
aList.Insert( pTmp );
}
}
void SwBlink::Delete( const SwLinePortion* pPor )
{
// setting direction to 0 because direction does not matter
// for this operation
SwBlinkPortion aBlink( pPor, 0 );
MSHORT nPos;
if( aList.Seek_Entry( &aBlink, &nPos ) )
aList.Remove( nPos );
}
void SwBlink::FrmDelete( const SwRootFrm* pRoot )
{
for( MSHORT nPos = 0; nPos < aList.Count(); )
{
if( pRoot == aList[ nPos ]->GetRootFrm() )
aList.Remove( nPos );
else
++nPos;
}
}