summaryrefslogtreecommitdiffstats
path: root/kpovmodeler/pmcontrolpoint.cpp
blob: 70cab9d46f1e69eba226cc89943aa430d3096311 (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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
**************************************************************************
                                 description
                             --------------------
    copyright            : (C) 2000-2001 by Andreas Zehender
    email                : [email protected]
**************************************************************************

**************************************************************************
*                                                                        *
*  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 of the License, or     *
*  (at your option) any later version.                                   *
*                                                                        *
**************************************************************************/

#include "pmcontrolpoint.h"
#include "pmdefaults.h"
#include "pmdebug.h"

#include <kconfig.h>

double PMControlPoint::s_moveGrid = c_defaultMoveGrid;
double PMControlPoint::s_scaleGrid = c_defaultScaleGrid;
double PMControlPoint::s_rotateGrid = c_defaultRotateGrid;

PMControlPoint::PMControlPoint( int id, const TQString& description )
{
   m_id = id;
   m_bChanged = false;
   m_description = description;
   m_bSelected = false;
}

PMControlPoint::~PMControlPoint( )
{
}

void PMControlPoint::startChange( const PMVector& s, const PMVector& n )
{
   m_startPoint = s;
   m_normalVector = n;
   graphicalChangeStarted( );
}

void PMControlPoint::change( const PMVector& endPoint )
{
   m_bChanged = true;
   graphicalChange( m_startPoint, m_normalVector, endPoint );
}
   
bool PMControlPoint::changed( )
{
   bool h = m_bChanged;
   m_bChanged = false;

   return h;
}

void PMControlPoint::setMoveGrid( double d )
{
   if( d > 0 )
      s_moveGrid = d;
   else
      kdError( PMArea ) << "Grid has to be greater than 0\n";
}

void PMControlPoint::setScaleGrid( double d )
{
   if( d > 0 )
      s_scaleGrid = d;
   else
      kdError( PMArea ) << "Grid has to be greater than 0\n";
}

void PMControlPoint::setRotateGrid( double d )
{
   if( d > 0 )
      s_rotateGrid = d;
   else
      kdError( PMArea ) << "Grid has to be greater than 0\n";
}

void PMControlPoint::saveConfig( TDEConfig* cfg )
{
   cfg->setGroup( "Grid" );
   cfg->writeEntry( "MoveGrid", s_moveGrid );
   cfg->writeEntry( "RotateGrid", s_rotateGrid );
   cfg->writeEntry( "ScaleGrid", s_scaleGrid );
}

void PMControlPoint::restoreConfig( TDEConfig* cfg )
{
   cfg->setGroup( "Grid" );
   s_moveGrid = cfg->readDoubleNumEntry( "MoveGrid", c_defaultMoveGrid );
   s_rotateGrid = cfg->readDoubleNumEntry( "RotateGrid", c_defaultRotateGrid );
   s_scaleGrid = cfg->readDoubleNumEntry( "ScaleGrid", c_defaultScaleGrid );
}