00001 // $Id: bmanip.cpp 1282 2006-06-09 09:46:49Z alex $ 00003 // Bitmap merging routines 00004 // DMc 17-3-98 00005 /* @@tag:xara-cn@@ DO NOT MODIFY THIS LINE 00006 ================================XARAHEADERSTART=========================== 00007 00008 Xara LX, a vector drawing and manipulation program. 00009 Copyright (C) 1993-2006 Xara Group Ltd. 00010 Copyright on certain contributions may be held in joint with their 00011 respective authors. See AUTHORS file for details. 00012 00013 LICENSE TO USE AND MODIFY SOFTWARE 00014 ---------------------------------- 00015 00016 This file is part of Xara LX. 00017 00018 Xara LX is free software; you can redistribute it and/or modify it 00019 under the terms of the GNU General Public License version 2 as published 00020 by the Free Software Foundation. 00021 00022 Xara LX and its component source files are distributed in the hope 00023 that it will be useful, but WITHOUT ANY WARRANTY; without even the 00024 implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 00025 See the GNU General Public License for more details. 00026 00027 You should have received a copy of the GNU General Public License along 00028 with Xara LX (see the file GPL in the root directory of the 00029 distribution); if not, write to the Free Software Foundation, Inc., 51 00030 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 00031 00032 00033 ADDITIONAL RIGHTS 00034 ----------------- 00035 00036 Conditional upon your continuing compliance with the GNU General Public 00037 License described above, Xara Group Ltd grants to you certain additional 00038 rights. 00039 00040 The additional rights are to use, modify, and distribute the software 00041 together with the wxWidgets library, the wxXtra library, and the "CDraw" 00042 library and any other such library that any version of Xara LX relased 00043 by Xara Group Ltd requires in order to compile and execute, including 00044 the static linking of that library to XaraLX. In the case of the 00045 "CDraw" library, you may satisfy obligation under the GNU General Public 00046 License to provide source code by providing a binary copy of the library 00047 concerned and a copy of the license accompanying it. 00048 00049 Nothing in this section restricts any of the rights you have under 00050 the GNU General Public License. 00051 00052 00053 SCOPE OF LICENSE 00054 ---------------- 00055 00056 This license applies to this program (XaraLX) and its constituent source 00057 files only, and does not necessarily apply to other Xara products which may 00058 in part share the same code base, and are subject to their own licensing 00059 terms. 00060 00061 This license does not apply to files in the wxXtra directory, which 00062 are built into a separate library, and are subject to the wxWindows 00063 license contained within that directory in the file "WXXTRA-LICENSE". 00064 00065 This license does not apply to the binary libraries (if any) within 00066 the "libs" directory, which are subject to a separate license contained 00067 within that directory in the file "LIBS-LICENSE". 00068 00069 00070 ARRANGEMENTS FOR CONTRIBUTION OF MODIFICATIONS 00071 ---------------------------------------------- 00072 00073 Subject to the terms of the GNU Public License (see above), you are 00074 free to do whatever you like with your modifications. However, you may 00075 (at your option) wish contribute them to Xara's source tree. You can 00076 find details of how to do this at: 00077 http://www.xaraxtreme.org/developers/ 00078 00079 Prior to contributing your modifications, you will need to complete our 00080 contributor agreement. This can be found at: 00081 http://www.xaraxtreme.org/developers/contribute/ 00082 00083 Please note that Xara will not accept modifications which modify any of 00084 the text between the start and end of this header (marked 00085 XARAHEADERSTART and XARAHEADEREND). 00086 00087 00088 MARKS 00089 ----- 00090 00091 Xara, Xara LX, Xara X, Xara X/Xtreme, Xara Xtreme, the Xtreme and Xara 00092 designs are registered or unregistered trademarks, design-marks, and/or 00093 service marks of Xara Group Ltd. All rights in these marks are reserved. 00094 00095 00096 Xara Group Ltd, Gaddesden Place, Hemel Hempstead, HP2 6EX, UK. 00097 http://www.xara.com/ 00098 00099 =================================XARAHEADEREND============================ 00100 */ 00101 00102 #include "camtypes.h" 00103 //#include "app.h" - in camtypes.h [AUTOMATICALLY REMOVED] 00104 #include "bmanip.h" 00105 00106 /****************************************************************************************** 00107 00108 > BOOL CBitmapManip::ApplyGaussianFilter(BYTE * bits, INT32 wid, INT32 hei, INT32 matrix[3][3], 00109 INT32 index) 00110 00111 00112 Author: David_McClarnon (Xara Group Ltd) <camelotdev@xara.com> 00113 Created: 1-10-98 00114 00115 Inputs: The source bitmap bits, its width and height and the matrix to apply 00116 00117 Returns: - 00118 00119 Purpose: Applies a 3x3 matrix to the bitmap's alpha channel 00120 00121 Notes: Remember DIB's are held upside-down in memory 00122 00123 ******************************************************************************************/ 00124 BOOL CBitmapManip::ApplyGaussianFilter(BYTE * bits, INT32 wid, INT32 hei, INT32 matrix[3][3], 00125 BOOL bIgnoreBlankPixels) 00126 { 00127 // we need a temporary bitmap 00128 INT32 ksize = (wid) * (hei) * 4; 00129 00130 BYTE * tmpBits = new BYTE[ksize]; 00131 00132 if (!tmpBits) 00133 return FALSE; 00134 00135 memcpy(tmpBits, bits, ksize); 00136 00137 INT32 size = wid * hei; 00138 size -= wid * 2; 00139 size -= 2; 00140 00141 COLORREF *srcPtr = ((COLORREF *)bits); 00142 COLORREF *destPtr = ((COLORREF *)tmpBits) + wid + 1; 00143 00144 UINT32 srcAlpha = 0; 00145 UINT32 destAlpha = 0; 00146 00147 INT32 incBy1 = wid*4; 00148 00149 INT32 sum = 0; 00150 00151 INT32 posX = 0; 00152 INT32 posY = 1; 00153 00154 COLORREF Area[3][3]; 00155 00156 INT32 i = 0; 00157 INT32 j = 0; 00158 00159 BYTE R = 0; 00160 BYTE A = 0; 00161 00162 INT32 SumR; 00163 INT32 SumA; 00164 00165 while (posY < hei - 1) 00166 { 00167 // transfer colour 00168 for (i = 0 ; i < 3; i++) 00169 { 00170 for (j = 0 ; j < 3; j++) 00171 { 00172 Area[i][j] = *(srcPtr + i * wid + j); 00173 } 00174 } 00175 00176 // now, ignore transparent areas 00177 if (((Area[1][1] & 0xff000000) >> 24) != 0xff || !bIgnoreBlankPixels) 00178 { 00179 SumR = 0; 00180 SumA = 0; 00181 sum = 0; 00182 00183 for (i = 0 ; i < 3; i++) 00184 { 00185 for (j = 0 ; j < 3; j++) 00186 { 00187 A = (BYTE)(Area[i][j] & 0xff000000) >> 24; 00188 R = (BYTE)(Area[i][j] & 0xff); 00189 00190 if (A != 0xff || !bIgnoreBlankPixels) 00191 { 00192 SumR += ((INT32)R) * matrix[i][j]; 00193 SumA += ((INT32)A) * matrix[i][j]; 00194 sum += matrix[i][j]; 00195 } 00196 } 00197 } 00198 00199 SumR /= sum; 00200 SumA /= sum; 00201 00202 *destPtr = SumR + (SumR << 8) + (SumR << 16) + (SumA << 24); 00203 } 00204 00205 // increment of pointers 00206 posX ++; 00207 00208 destPtr ++; 00209 srcPtr ++; 00210 00211 if (posX >= wid - 3) 00212 { 00213 destPtr += 3; 00214 srcPtr += 3; 00215 posX = 0; 00216 posY ++; 00217 } 00218 } 00219 00220 memcpy(bits, tmpBits, wid * hei * 4); 00221 00222 delete [] tmpBits; 00223 00224 return TRUE; 00225 }