nsIImageToBitmap.h
Go to the documentation of this file.
1 /* vim: fileencoding=utf-8 shiftwidth=4 */
2 /* ***** BEGIN LICENSE BLOCK *****
3  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4  *
5  * The contents of this file are subject to the Mozilla Public License Version
6  * 1.1 (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  * http://www.mozilla.org/MPL/
9  *
10  * Software distributed under the License is distributed on an "AS IS" basis,
11  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12  * for the specific language governing rights and limitations under the
13  * License.
14  *
15  * The Original Code is mozilla.org widget code.
16  *
17  * The Initial Developer of the Original Code is
18  * Matthew Gertner <matthew@allpeers.com>.
19  * Portions created by the Initial Developer are Copyright (C) 2007
20  * AllPeers Ltd. All Rights Reserved.
21  *
22  * Contributor(s):
23  *
24  * Alternatively, the contents of this file may be used under the terms of
25  * either the GNU General Public License Version 2 or later (the "GPL"), or
26  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27  * in which case the provisions of the GPL or the LGPL are applicable instead
28  * of those above. If you wish to allow use of your version of this file only
29  * under the terms of either the GPL or the LGPL, and not to allow others to
30  * use your version of this file under the terms of the MPL, indicate your
31  * decision by deleting the provisions above and replace them with the notice
32  * and other provisions required by the GPL or the LGPL. If you do not delete
33  * the provisions above, a recipient may use your version of this file under
34  * the terms of any one of the MPL, the GPL or the LGPL.
35  *
36  * ***** END LICENSE BLOCK ***** */
37 
38 #ifndef NSIIMAGETOBITMAP_H_
39 #define NSIIMAGETOBITMAP_H_
40 
41 #include "nsISupports.h"
42 
43 // {337D3FFB-F15F-4df5-83E5-4C7C3D595392}
44 #define NSIIMAGETOBITMAP_IID \
45 { 0x337d3ffb, 0xf15f, 0x4df5, \
46  { 0x83, 0xe5, 0x4c, 0x7c, 0x3d, 0x59, 0x53, 0x92 } }
47 
48 class gfxImageSurface;
49 
50 struct HBITMAP__;
51 struct HICON__;
52 
53 typedef struct HBITMAP__ *HBITMAP;
54 typedef struct HICON__ *HICON;
55 typedef HICON HCURSOR;
56 
60 class nsIImageToBitmap : public nsISupports {
61  public:
62  NS_DECLARE_STATIC_IID_ACCESSOR(NSIIMAGETOBITMAP_IID)
63 
64  // convert an image to a DDB
65  NS_IMETHOD ConvertImageToBitmap(gfxImageSurface* aImage,
66  HBITMAP& outBitmap) = 0;
67 
68  // convert an image to a HICON
69  NS_IMETHOD ConvertImageToIcon(gfxImageSurface* aImage,
70  HICON& outIcon) = 0;
71 
72  // convert an image to a HCURSOR
73  NS_IMETHOD ConvertImageToCursor(gfxImageSurface* aImage,
74  PRUint32 aHotspotX,
75  PRUint32 aHotspotY,
76  HCURSOR& outCursor) = 0;
77 };
78 
79 NS_DEFINE_STATIC_IID_ACCESSOR(nsIImageToBitmap, NSIIMAGETOBITMAP_IID)
80 
81 #endif
NS_IMETHOD ConvertImageToBitmap(gfxImageSurface *aImage, HBITMAP &outBitmap)=0
struct HICON__ * HICON
NS_IMETHOD ConvertImageToIcon(gfxImageSurface *aImage, HICON &outIcon)=0
struct HBITMAP__ * HBITMAP
NS_IMETHOD ConvertImageToCursor(gfxImageSurface *aImage, PRUint32 aHotspotX, PRUint32 aHotspotY, HCURSOR &outCursor)=0
HICON HCURSOR
#define NSIIMAGETOBITMAP_IID