1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef _SDR_ANIMATION_SCHEDULER_HXX
21 #define _SDR_ANIMATION_SCHEDULER_HXX
23 #include <sal/types.h>
24 #include <vcl/timer.hxx>
25 #include <svx/svxdllapi.h>
27 //////////////////////////////////////////////////////////////////////////////
36 // time of event in ms
39 // pointer for simply linked list
43 // constructor/destructor
44 explicit Event(sal_uInt32 nTime
);
45 SVX_DLLPUBLIC
virtual ~Event();
48 Event
* GetNext() const;
49 void SetNext(Event
* pNew
);
52 sal_uInt32
GetTime() const;
53 void SVX_DLLPUBLIC
SetTime(sal_uInt32 nNew
);
56 virtual void Trigger(sal_uInt32 nTime
) = 0;
58 } // end of namespace animation
59 } // end of namespace sdr
61 //////////////////////////////////////////////////////////////////////////////
70 // pointer to first entry
74 // constructor/destructor
76 SVX_DLLPUBLIC
virtual ~EventList();
78 // insert/remove time dependent
79 void Insert(Event
* pNew
);
80 void Remove(Event
* pOld
);
88 } // end of namespace animation
89 } // end of namespace sdr
91 //////////////////////////////////////////////////////////////////////////////
98 class Scheduler
: public Timer
104 sal_uInt32 mnDeltaTime
;
109 // Flag which remembers if this timer is paused. Default
114 // constructor/destructor
116 SVX_DLLPUBLIC
virtual ~Scheduler();
118 // From baseclass Timer, the timeout call
119 SVX_DLLPUBLIC
virtual void Timeout();
122 sal_uInt32
GetTime();
125 void SetTime(sal_uInt32 nTime
);
127 // execute all ripe events, removes executed ones from the scheduler
128 void triggerEvents();
130 // re-start or stop timer according to event list
133 // insert/remove events, wrapper to EventList methods
134 void SVX_DLLPUBLIC
InsertEvent(Event
* pNew
);
135 void RemoveEvent(Event
* pOld
);
138 bool IsPaused() const { return mbIsPaused
; }
139 void SetPaused(bool bNew
);
141 } // end of namespace animation
142 } // end of namespace sdr
144 //////////////////////////////////////////////////////////////////////////////
146 #endif //_SDR_ANIMATION_SCHEDULER_HXX
148 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */