1*b1cdbd2cSJim Jagielski/**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_report_XImageControl_idl__
24*b1cdbd2cSJim Jagielski#define __com_sun_star_report_XImageControl_idl__
25*b1cdbd2cSJim Jagielski
26*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_report_XReportControlModel_idl__
27*b1cdbd2cSJim Jagielski#include <com/sun/star/report/XReportControlModel.idl>
28*b1cdbd2cSJim Jagielski#endif
29*b1cdbd2cSJim Jagielski#ifndef __com_sun_star_form_XImageProducerSupplier_idl__
30*b1cdbd2cSJim Jagielski#include <com/sun/star/form/XImageProducerSupplier.idl>
31*b1cdbd2cSJim Jagielski#endif
32*b1cdbd2cSJim Jagielski
33*b1cdbd2cSJim Jagielski//=============================================================================
34*b1cdbd2cSJim Jagielski
35*b1cdbd2cSJim Jagielski module com {  module sun {  module star {  module report {
36*b1cdbd2cSJim Jagielski
37*b1cdbd2cSJim Jagielski//=============================================================================
38*b1cdbd2cSJim Jagielskipublished interface XImageControl
39*b1cdbd2cSJim Jagielski{
40*b1cdbd2cSJim Jagielski    interface XReportControlModel;
41*b1cdbd2cSJim Jagielski
42*b1cdbd2cSJim Jagielski    /** supplies the caller with an <type scope="com::sun::star::awt">XImageProducer</type>.
43*b1cdbd2cSJim Jagielski
44*b1cdbd2cSJim Jagielski        <p>Other components can register as <type scope="com::sun::star::awt">XImageConsumer</type>
45*b1cdbd2cSJim Jagielski        at this producer. Then they will be notified of any change in the image to be displayed.</p>
46*b1cdbd2cSJim Jagielski
47*b1cdbd2cSJim Jagielski        <p>Whenever the <member scope="com::sun::star::awt">UnoControlImageControlModel::ImageURL</member>
48*b1cdbd2cSJim Jagielski        property is changed, the model loads the specified image, and sets it as image source
49*b1cdbd2cSJim Jagielski        at its <type scope="com::sun::star::awt">XImageProducer</type>. Then, all
50*b1cdbd2cSJim Jagielski        <type scope="com::sun::star::awt">XImageConsumer</type>s are notified and supplied with
51*b1cdbd2cSJim Jagielski        the binary data of the image.<br/>
52*b1cdbd2cSJim Jagielski        Usually, controls acting for an <type>ImageControl</type> model are consumers, and use the
53*b1cdbd2cSJim Jagielski        data stream to display the image</p>
54*b1cdbd2cSJim Jagielski     */
55*b1cdbd2cSJim Jagielski    interface com::sun::star::form::XImageProducerSupplier;
56*b1cdbd2cSJim Jagielski
57*b1cdbd2cSJim Jagielski    /** specifies an URL to an image to use for the control.
58*b1cdbd2cSJim Jagielski     */
59*b1cdbd2cSJim Jagielski    [attribute,bound] string ImageURL;
60*b1cdbd2cSJim Jagielski
61*b1cdbd2cSJim Jagielski    /** defines how to scale the image
62*b1cdbd2cSJim Jagielski
63*b1cdbd2cSJim Jagielski        <p>If this property is present, it supersedes the <member>ScaleImage</member> property.</p>
64*b1cdbd2cSJim Jagielski
65*b1cdbd2cSJim Jagielski        <p>The value of this property is one of the <type scope="com::sun::star::awt">ImageScaleMode</type> constants.</p>
66*b1cdbd2cSJim Jagielski
67*b1cdbd2cSJim Jagielski        @since OpenOffice 3.2
68*b1cdbd2cSJim Jagielski    */
69*b1cdbd2cSJim Jagielski    [attribute,bound] short ScaleMode
70*b1cdbd2cSJim Jagielski    {
71*b1cdbd2cSJim Jagielski        set raises (com::sun::star::lang::IllegalArgumentException);
72*b1cdbd2cSJim Jagielski    };
73*b1cdbd2cSJim Jagielski
74*b1cdbd2cSJim Jagielski    /** Specifies that the IRI given in the data field should be preserved, otherwise the content will be inserted in the resulting report document.
75*b1cdbd2cSJim Jagielski        If the data field contains something different as string then this attribute will be ignored.
76*b1cdbd2cSJim Jagielski    */
77*b1cdbd2cSJim Jagielski    [attribute,bound] boolean PreserveIRI;
78*b1cdbd2cSJim Jagielski};
79*b1cdbd2cSJim Jagielski
80*b1cdbd2cSJim Jagielskipublished service ImageControl : XImageControl;
81*b1cdbd2cSJim Jagielski//=============================================================================
82*b1cdbd2cSJim Jagielski
83*b1cdbd2cSJim Jagielski}; }; }; };
84*b1cdbd2cSJim Jagielski
85*b1cdbd2cSJim Jagielski/*=============================================================================
86*b1cdbd2cSJim Jagielski
87*b1cdbd2cSJim Jagielski=============================================================================*/
88*b1cdbd2cSJim Jagielski#endif
89