Bump version to 24.04.3.4
[LibreOffice.git] / slideshow / source / inc / iexternalmediashapebase.hxx
blob1a70ae09365291c52fcbd0b2fb85d06f46021d30
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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 INCLUDED_SLIDESHOW_SOURCE_INC_IEXTERNALMEDIASHAPEBASE_HXX
21 #define INCLUDED_SLIDESHOW_SOURCE_INC_IEXTERNALMEDIASHAPEBASE_HXX
23 #include <memory>
25 #include "shape.hxx"
28 namespace slideshow::internal
30 /** Represents a shape containing playable content rendered by
31 external engine (e.g. media or applet).
33 This interface adds media handling methods to a shape. It
34 allows starting/stopping and pausing playback.
36 class IExternalMediaShapeBase : public Shape
38 public:
39 // Animation methods
42 /** Notify the Shape that it should start with playback
44 This method enters playback mode on all registered
45 views. It makes the media initially visible (for videos).
47 virtual void play() = 0;
49 /** Notify the Shape that it should stop playback
51 This method leaves playback mode on all registered
52 views. The media is then rewound to the start, and
53 removed from screen (for videos)
55 virtual void stop() = 0;
57 /** Notify the Shape that it should pause playback
59 This method stops playback on all registered
60 views. The media stays visible (for videos)
62 virtual void pause() = 0;
64 /** Query whether the media is currently playing.
66 virtual bool isPlaying() const = 0;
68 /** Set media time in seconds.
70 @param fTime
71 Time in seconds of the media time line, that should now be
72 presented
74 virtual void setMediaTime(double fTime) = 0;
76 virtual void setLooping(bool /*bLooping*/){};
79 typedef ::std::shared_ptr< IExternalMediaShapeBase > IExternalMediaShapeBaseSharedPtr;
83 #endif // INCLUDED_SLIDESHOW_SOURCE_INC_IEXTERNALMEDIASHAPEBASE_HXX
85 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */