Version 4.2.0.1, tag libreoffice-4.2.0.1
[LibreOffice.git] / cppcanvas / source / mtfrenderer / transparencygroupaction.hxx
blob221864dbb3f15fb57d11e79b787cee305057f902
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 _CPPCANVAS_TRANSPARENCYGROUPACTION_HXX
21 #define _CPPCANVAS_TRANSPARENCYGROUPACTION_HXX
23 #include <cppcanvas/canvas.hxx>
24 #include <cppcanvas/renderer.hxx>
25 #include <action.hxx>
27 #include <memory>
29 namespace basegfx {
30 class B2DPoint;
31 class B2DVector;
34 class GDIMetaFile;
35 class Gradient;
38 /* Definition of internal::TransparencyGroupActionFactory class */
40 namespace cppcanvas
42 namespace internal
44 struct OutDevState;
46 typedef ::std::auto_ptr< GDIMetaFile > MtfAutoPtr;
47 typedef ::std::auto_ptr< Gradient > GradientAutoPtr;
49 /** Transparency group action.
51 This action groups a bunch of other actions, to be
52 rendered with the given transparency setting against the
53 background.
55 Creates encapsulated converters between GDIMetaFile and
56 XCanvas. The Canvas argument is deliberately placed at the
57 constructor, to force reconstruction of this object for a
58 new canvas. This considerably eases internal state
59 handling, since a lot of the internal state (e.g. fonts,
60 text layout) is Canvas-dependent.
62 class TransparencyGroupActionFactory
64 public:
65 /** Create new transparency group action.
67 @param rGroupMtf
68 Metafile that groups all actions to be rendered
69 transparent.
71 @param rAlphaGradient
72 VCL gradient, to be rendered into the action's alpha
73 channel.
75 @param rParms
76 Render parameters
78 @param rDstPoint
79 Left, top edge of destination, in current state
80 coordinate system
82 @param rDstSize
83 Size of the transparency group object, in current
84 state coordinate system.
86 static ActionSharedPtr createTransparencyGroupAction( MtfAutoPtr& rGroupMtf,
87 GradientAutoPtr& rAlphaGradient,
88 const Renderer::Parameters& rParms,
89 const ::basegfx::B2DPoint& rDstPoint,
90 const ::basegfx::B2DVector& rDstSize,
91 const CanvasSharedPtr& rCanvas,
92 const OutDevState& rState );
94 private:
95 // static factory, disable big four
96 TransparencyGroupActionFactory();
97 ~TransparencyGroupActionFactory();
98 TransparencyGroupActionFactory(const TransparencyGroupActionFactory&);
99 TransparencyGroupActionFactory& operator=( const TransparencyGroupActionFactory& );
104 #endif /*_CPPCANVAS_TRANSPARENCYGROUPACTION_HXX */
106 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */