Accessor for ClosedCaptionsDialog.
[dcpomatic.git] / src / lib / image_proxy.h
1 /*
2     Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #ifndef DCPOMATIC_IMAGE_PROXY_H
22 #define DCPOMATIC_IMAGE_PROXY_H
23
24 /** @file  src/lib/image_proxy.h
25  *  @brief ImageProxy and subclasses.
26  */
27
28 extern "C" {
29 #include <libavutil/pixfmt.h>
30 }
31 #include <dcp/types.h>
32 #include <boost/shared_ptr.hpp>
33 #include <boost/optional.hpp>
34 #include <boost/utility.hpp>
35
36 class Image;
37 class Socket;
38
39 namespace xmlpp {
40         class Node;
41 }
42
43 namespace cxml {
44         class Node;
45 }
46
47 /** @class ImageProxy
48  *  @brief A class which holds an Image, and can produce it on request.
49  *
50  *  This is so that decoding of source images can be postponed until
51  *  the encoder thread, where multi-threading is happening, instead
52  *  of happening in a single-threaded decoder.
53  *
54  *  For example, large TIFFs are slow to decode, so this class will keep
55  *  the TIFF data compressed until the decompressed image is needed.
56  *  At this point, the class decodes the TIFF to an Image.
57  */
58 class ImageProxy : public boost::noncopyable
59 {
60 public:
61         virtual ~ImageProxy () {}
62
63         /** @param log Log to write to, or 0.
64          *  @param size Size that the returned image will be scaled to, in case this
65          *  can be used as an optimisation.
66          *  @return Image (which must be aligned) and log2 of any scaling down that has
67          *  already been applied to the image; e.g. if the the image is already half the size
68          *  of the original, the second part of the return value will be 1.
69          */
70         virtual std::pair<boost::shared_ptr<Image>, int> image (
71                 boost::optional<dcp::Size> size = boost::optional<dcp::Size> ()
72                 ) const = 0;
73
74         virtual void add_metadata (xmlpp::Node *) const = 0;
75         virtual void send_binary (boost::shared_ptr<Socket>) const = 0;
76         /** @return true if our image is definitely the same as another, false if it is probably not */
77         virtual bool same (boost::shared_ptr<const ImageProxy>) const = 0;
78         /** Do any useful work that would speed up a subsequent call to ::image().
79          *  This method may be called in a different thread to image().
80          *  @return log2 of any scaling down that will be applied to the image.
81          */
82         virtual int prepare (boost::optional<dcp::Size> = boost::optional<dcp::Size>()) const { return 0; }
83         virtual size_t memory_used () const = 0;
84 };
85
86 boost::shared_ptr<ImageProxy> image_proxy_factory (boost::shared_ptr<cxml::Node> xml, boost::shared_ptr<Socket> socket);
87
88 #endif