Initial revision
[blender.git] / source / blender / img / intern / IMG_Api.cpp
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. The Blender
10  * Foundation also sells licenses for use in proprietary software under
11  * the Blender License.  See http://www.blender.org/BL/ for information
12  * about this.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software Foundation,
21  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  *
23  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
24  * All rights reserved.
25  *
26  * The Original Code is: all of this file.
27  *
28  * Contributor(s): none yet.
29  *
30  * ***** END GPL/BL DUAL LICENSE BLOCK *****
31  */
32 #include "../IMG_Api.h"
33
34 #include "IMG_BrushRGBA32.h"
35 #include "IMG_CanvasRGBA32.h"
36
37
38 IMG_BrushPtr IMG_BrushCreate(unsigned int w, unsigned int h, float r, float g, float b, float a)
39 {
40         IMG_BrushPtr brush = 0;
41         try {
42                 IMG_ColorRGB c (r, g, b);
43                 brush = new IMG_BrushRGBA32 (w, h, c, a);
44         }
45         catch (...) {
46                 brush = 0;
47         }
48         return brush;
49 }
50
51
52 void IMG_BrushDispose(IMG_BrushPtr brush)
53 {
54         if (brush) {
55                 delete ((IMG_BrushRGBA32*)brush);
56                 brush = 0;
57         }
58 }
59
60
61 IMG_CanvasPtr IMG_CanvasCreate(unsigned int w, unsigned int h)
62 {
63         IMG_CanvasPtr canvas = 0;
64         try {
65                 canvas = new IMG_CanvasRGBA32 (w, h);
66         }
67         catch (...) {
68                 canvas = 0;
69         }
70         return canvas;
71 }
72
73
74 IMG_CanvasPtr IMG_CanvasCreateFromPtr(void* imagePtr, unsigned int w, unsigned int h, size_t rowBytes)
75 {
76         IMG_CanvasPtr canvas = 0;
77         try {
78                 canvas = new IMG_CanvasRGBA32 (imagePtr, w, h, rowBytes);
79         }
80         catch (...) {
81                 canvas = 0;
82         }
83         return canvas;
84 }
85
86 void IMG_CanvasDispose(IMG_CanvasPtr canvas)
87 {
88         if (canvas) {
89                 delete ((IMG_CanvasRGBA32*)canvas);
90                 canvas = 0;
91         }
92 }
93
94 #if 0
95 void IMG_CanvasDraw(IMG_CanvasPtr canvas, IMG_BrushPtr brush, unsigned int x, unsigned int y)
96 {
97         if (!(canvas && brush)) return;
98         ((IMG_CanvasRGBA32*)canvas)->blendPixmap((TUns32)x, (TUns32)y, *((IMG_BrushRGBA32*)brush));
99 }
100
101
102 void IMG_CanvasDrawUV(IMG_CanvasPtr canvas, IMG_BrushPtr brush, float u, float v)
103 {
104         if (!(canvas && brush)) return;
105         ((IMG_CanvasRGBA32*)canvas)->blendPixmap(u, v, *((IMG_BrushRGBA32*)brush));
106 }
107 #endif
108
109
110 void IMG_CanvasDrawLine(IMG_CanvasPtr canvas, IMG_BrushPtr brush, unsigned int xStart, unsigned int yStart, unsigned int xEnd, unsigned int yEnd)
111 {
112         if (!(canvas && brush)) return;
113         ((IMG_CanvasRGBA32*)canvas)->blendPixmap((TUns32)xStart, (TUns32)yStart, (TUns32)xEnd, (TUns32)yEnd, *((IMG_BrushRGBA32*)brush));
114 }
115
116
117 void IMG_CanvasDrawLineUV(IMG_CanvasPtr canvas, IMG_BrushPtr brush, float uStart, float vStart, float uEnd, float vEnd)
118 {
119         if (!(canvas && brush)) return;
120         ((IMG_CanvasRGBA32*)canvas)->blendPixmap(uStart, vStart, uEnd, vEnd, *((IMG_BrushRGBA32*)brush));
121 }