1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
/*
/--------------------------------------------------------------------
|
| $Id: plfiltervideoinvert.cpp,v 1.9 2004/09/11 12:41:36 uzadow Exp $
|
| Copyright (c) 1996-2002 Ulrich von Zadow
|
\--------------------------------------------------------------------
*/
#include "plfilter.h"
#include "plfiltervideoinvert.h"
#include "plbitmap.h"
#include "plhsvconvert.h"
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
PLFilterVideoInvert::PLFilterVideoInvert() : PLFilter()
{
}
PLFilterVideoInvert::~PLFilterVideoInvert()
{
}
void PLFilterVideoInvert::Apply(PLBmpBase *pBmpSource, PLBmp *pBmpDest) const
{
// Only works for 32 bpp bitmaps at the moment.
PLASSERT (pBmpSource->GetBitsPerPixel() == 32);
pBmpDest->Create (pBmpSource->GetWidth(), pBmpSource->GetHeight(),
PLPixelFormat::X8R8G8B8, NULL, 0, pBmpSource->GetResolution());
PLBYTE ** pSrcLines = pBmpSource->GetLineArray();
PLBYTE ** pDstLines = pBmpDest->GetLineArray();
for (int y = 0; y<pBmpDest->GetHeight(); ++y)
{ // For each line
PLBYTE * pSrcPixel = pSrcLines[y];
PLBYTE * pDstPixel = pDstLines[y];
for (int x = 0; x < pBmpDest->GetWidth(); ++x)
{ // For each pixel
double v1, v2, v3;
v1 = (double)pSrcPixel[PL_RGBA_RED];
v2 = (double)pSrcPixel[PL_RGBA_GREEN];
v3 = (double)pSrcPixel[PL_RGBA_BLUE];
fp_rgb_to_hsv(&v1, &v2, &v3);
v3 = 255.0-v3;
fp_hsv_to_rgb(&v1, &v2, &v3);
*pDstPixel = (int)v3;
pDstPixel++;
*pDstPixel = (int)v2;
pDstPixel++;
*pDstPixel = (int)v1;
pDstPixel++;
pDstPixel++;
/*PLBYTE (pSrcPixel[PL_RGBA_RED]*0.212671+
pSrcPixel[PL_RGBA_GREEN]*0.715160+
pSrcPixel[PL_RGBA_BLUE]*0.072169);*/
pSrcPixel += sizeof(PLPixel32);
}
}
}
/*
/--------------------------------------------------------------------
|
| $Log: plfiltervideoinvert.cpp,v $
| Revision 1.9 2004/09/11 12:41:36 uzadow
| removed plstdpch.h
|
| Revision 1.8 2004/09/09 16:52:45 artcom
| refactored PixelFormat
|
| Revision 1.7 2004/06/15 10:26:13 uzadow
| Initial nonfunctioning version of plbmpbase.
|
| Revision 1.6 2003/11/05 15:17:26 artcom
| Added ability to specify initial data in PLBitmap::Create()
|
| Revision 1.5 2002/08/04 20:08:01 uzadow
| Added PLBmpInfo class, ability to extract metainformation from images without loading the whole image and proper greyscale support.
|
| Revision 1.4 2002/03/31 13:36:42 uzadow
| Updated copyright.
|
| Revision 1.3 2001/10/16 17:12:27 uzadow
| Added support for resolution information (Luca Piergentili)
|
| Revision 1.2 2001/10/06 22:37:08 uzadow
| Linux compatibility.
|
| Revision 1.1 2001/09/16 19:03:23 uzadow
| Added global name prefix PL, changed most filenames.
|
| Revision 1.5 2001/02/04 14:31:52 uzadow
| Member initialization list cleanup (Erik Hoffmann).
|
| Revision 1.4 2001/01/15 15:05:31 uzadow
| Added PLBmp::ApplyFilter() and PLBmp::CreateFilteredCopy()
|
| Revision 1.3 2000/12/18 22:42:53 uzadow
| Replaced RGBAPIXEL with PLPixel32.
|
| Revision 1.2 2000/10/12 21:56:12 uzadow
| Moved local functions from VideoInvertFilter.cpp to
| hsvconvert.*
|
| Revision 1.1 2000/03/31 12:20:06 Ulrich von Zadow
| Video invert filter (beta)
|
|
|
\--------------------------------------------------------------------
*/
|