1*c45d927aSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*c45d927aSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*c45d927aSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*c45d927aSAndrew Rist  * distributed with this work for additional information
6*c45d927aSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*c45d927aSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*c45d927aSAndrew Rist  * "License"); you may not use this file except in compliance
9*c45d927aSAndrew Rist  * with the License.  You may obtain a copy of the License at
10*c45d927aSAndrew Rist  *
11*c45d927aSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*c45d927aSAndrew Rist  *
13*c45d927aSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*c45d927aSAndrew Rist  * software distributed under the License is distributed on an
15*c45d927aSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*c45d927aSAndrew Rist  * KIND, either express or implied.  See the License for the
17*c45d927aSAndrew Rist  * specific language governing permissions and limitations
18*c45d927aSAndrew Rist  * under the License.
19*c45d927aSAndrew Rist  *
20*c45d927aSAndrew Rist  *************************************************************/
21*c45d927aSAndrew Rist 
22*c45d927aSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir #include "precompiled_sd.hxx"
25cdf0e10cSrcweir 
26cdf0e10cSrcweir #include "slideshow.hxx"
27cdf0e10cSrcweir #include "ViewShellBase.hxx"
28cdf0e10cSrcweir #include <rtl/ref.hxx>
29cdf0e10cSrcweir #include <tools/link.hxx>
30cdf0e10cSrcweir #include <boost/enable_shared_from_this.hpp>
31cdf0e10cSrcweir 
32cdf0e10cSrcweir namespace sd {
33cdf0e10cSrcweir 
34cdf0e10cSrcweir /** This class is used when a display is removed or added to restart the
35cdf0e10cSrcweir     slide show.  This is necessary at least with DirectX because
36cdf0e10cSrcweir     deactivating a display invalidates DirectX resources.  Accessing those
37cdf0e10cSrcweir     leads to a crash.
38cdf0e10cSrcweir 
39cdf0e10cSrcweir     During a restart a possibly installed presenter extension is given the
40cdf0e10cSrcweir     oportunity to show or hide depending on the number of available displays.
41cdf0e10cSrcweir */
42cdf0e10cSrcweir class SlideShowRestarter
43cdf0e10cSrcweir     : public boost::enable_shared_from_this<SlideShowRestarter>
44cdf0e10cSrcweir {
45cdf0e10cSrcweir public:
46cdf0e10cSrcweir     /** Create a new SlideShowRestarter object.
47cdf0e10cSrcweir         @param rpSlideShow
48cdf0e10cSrcweir             The slide show is used to determine the current slide, which is
49cdf0e10cSrcweir             restored after the restart, and of course to stop and start the
50cdf0e10cSrcweir             slide show.
51cdf0e10cSrcweir         @param pViewShellBase
52cdf0e10cSrcweir             Used to get access to a slot dispatcher.
53cdf0e10cSrcweir     */
54cdf0e10cSrcweir     SlideShowRestarter (
55cdf0e10cSrcweir         const ::rtl::Reference<SlideShow>& rpSlideShow,
56cdf0e10cSrcweir         ViewShellBase* pViewShellBase);
57cdf0e10cSrcweir     virtual ~SlideShowRestarter (void);
58cdf0e10cSrcweir 
59cdf0e10cSrcweir     /** Restarting the slide show is an asynchronous multi step process
60cdf0e10cSrcweir         which is started by calling this method.
61cdf0e10cSrcweir     */
62cdf0e10cSrcweir     void Restart (void);
63cdf0e10cSrcweir 
64cdf0e10cSrcweir private:
65cdf0e10cSrcweir     sal_Int32 mnEventId;
66cdf0e10cSrcweir     ::rtl::Reference<SlideShow> mpSlideShow;
67cdf0e10cSrcweir     ViewShellBase* mpViewShellBase;
68cdf0e10cSrcweir     ::boost::shared_ptr<SlideShowRestarter> mpSelf;
69cdf0e10cSrcweir     sal_Int32 mnDisplayCount;
70cdf0e10cSrcweir     SfxDispatcher* mpDispatcher;
71cdf0e10cSrcweir     sal_Int32 mnCurrentSlideNumber;
72cdf0e10cSrcweir 
73cdf0e10cSrcweir     /** The display count is used to determine whether the number of
74cdf0e10cSrcweir         displays has changed and thus whether restarting the slide show is
75cdf0e10cSrcweir         really necessary.
76cdf0e10cSrcweir     */
77cdf0e10cSrcweir     sal_Int32 GetDisplayCount (void);
78cdf0e10cSrcweir 
79cdf0e10cSrcweir     DECL_LINK(EndPresentation, void*);
80cdf0e10cSrcweir 
81cdf0e10cSrcweir     /** Restart the presentation on the slide last shown before the restart
82cdf0e10cSrcweir         was initiated.
83cdf0e10cSrcweir     */
84cdf0e10cSrcweir     void StartPresentation (void);
85cdf0e10cSrcweir };
86cdf0e10cSrcweir 
87cdf0e10cSrcweir } // end of namespace sd
88