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
|
/* ============================================================
*
* This file is a part of digiKam project
* http://www.digikam.org
*
* Date : 2005-05-25
* Description : Raindrop threaded image filter.
*
* Copyright (C) 2005-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
* Copyright (C) 2006-2007 by Marcel Wiesweg <marcel dot wiesweg at gmx dot de>
*
* This program is free software; you can redistribute it
* and/or modify it under the terms of the GNU General
* Public License as published by the Free Software Foundation;
* either version 2, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* ============================================================ */
#ifndef RAINDROP_H
#define RAINDROP_H
// Digikam includes.
#include "dimgthreadedfilter.h"
class TQRect;
namespace DigikamRainDropImagesPlugin
{
class RainDrop : public Digikam::DImgThreadedFilter
{
public:
RainDrop(Digikam::DImg *orgImage, TQObject *parent=0, int drop=80,
int amount=150, int coeff=30, TQRect *selection=0L);
~RainDrop(){};
private:
virtual void filterImage(void);
void rainDropsImage(Digikam::DImg *orgImage, Digikam::DImg *destImage, int MinDropSize, int MaxDropSize,
int Amount, int Coeff, bool bLimitRange, int progressMin, int progressMax);
bool CreateRainDrop(uchar *pBits, int Width, int Height, bool sixteenBit, int bytesDepth,
uchar *pResBits, uchar* pStatusBits,
int X, int Y, int DropSize, double Coeff, bool bLimitRange);
bool CanBeDropped(int Width, int Height, uchar *pStatusBits, int X, int Y, int DropSize, bool bLimitRange);
bool SetDropStatusBits (int Width, int Height, uchar *pStatusBits, int X, int Y, int DropSize);
// A color is represented in RGB value (e.g. 0xFFFFFF is white color).
// But R, G and B values has 256 values to be used so, this function analize
// the value and limits to this range.
inline int LimitValues8(int ColorValue)
{
if (ColorValue > 255) ColorValue = 255;
if (ColorValue < 0) ColorValue = 0;
return ColorValue;
};
inline int LimitValues16(int ColorValue)
{
if (ColorValue > 65535) ColorValue = 65535;
if (ColorValue < 0) ColorValue = 0;
return ColorValue;
};
inline bool IsInside (int Width, int Height, int X, int Y)
{
bool bIsWOk = ((X < 0) ? false : (X >= Width ) ? false : true);
bool bIsHOk = ((Y < 0) ? false : (Y >= Height) ? false : true);
return (bIsWOk && bIsHOk);
};
inline int Offset(int Width, int X, int Y, int bytesDepth)
{
return (Y * Width * bytesDepth + X * bytesDepth);
};
private:
int m_drop;
int m_amount;
int m_coeff;
int m_selectedX;
int m_selectedY;
int m_selectedW;
int m_selectedH;
};
} // NameSpace DigikamRainDropImagesPlugin
#endif /* RAINDROP_H */
|