summaryrefslogtreecommitdiffstats
path: root/src/imageplugins/sheartool/shear.h
blob: 480d1084e2882b3f3098cb58a07cf5167a36f02d (plain)
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
/* ============================================================
 *
 * This file is a part of digiKam project
 * http://www.digikam.org
 *
 * Date        : 2005-07-18
 * Description : Shear threaded image filter.
 *
 * Copyright (C) 2005-2008 by Gilles Caulier <caulier dot gilles at gmail dot com>
 *
 * 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 SHEAR_H
#define SHEAR_H

// TQt includes.

#include <tqsize.h>
#include <tqcolor.h>

// Digikam includes.

#include "dimgthreadedfilter.h"

namespace DigikamShearToolImagesPlugin
{

class Shear : public Digikam::DImgThreadedFilter
{

public:

    Shear(Digikam::DImg *orgImage, TQObject *parent=0, float hAngle=0.0, float vAngle=0.0,
          bool antialiasing=true, TQColor backgroundColor=TQt::black, int orgW=0, int orgH=0);

    ~Shear(){};

    TQSize getNewSize(void){ return m_newSize; };

private:  

    virtual void filterImage(void);

    inline int setPosition (int Width, int X, int Y)
    {
       return (Y *Width*4 + 4*X); 
    };

    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);
    };

private:

    bool   m_antiAlias;

    int    m_orgW;
    int    m_orgH;

    float  m_hAngle;
    float  m_vAngle;

    TQColor m_backgroundColor;

    TQSize  m_newSize;
};

}  // NameSpace DigikamShearToolImagesPlugin

#endif /* SHEAR_H */