File: Transform.h

package info (click to toggle)
veroroute 2.38-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,044 kB
  • sloc: cpp: 21,512; xml: 89; sh: 65; lisp: 20; makefile: 5
file content (61 lines) | stat: -rw-r--r-- 2,075 bytes parent folder | download
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
/*
	VeroRoute - Qt based Veroboard/Perfboard/PCB layout & routing application.

	Copyright (C) 2017  Alex Lawrow    ( dralx@users.sourceforge.net )

	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 3 of the License, 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.

	You should have received a copy of the GNU General Public License
	along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

#pragma once

#include "Common.h"
#include <QPointF>

// Class to transform a QPointF (i.e. translate/rotate it w.r.t. the origin)

enum class TRANSFORM { NONE = 0, SCALE, TRANSLATE, ROTATE };

struct Transform
{
	Transform(TRANSFORM eType, qreal a = 0, qreal b = 0) : m_eType(eType), m_A(a), m_B(b) {}
	~Transform() {}
	Transform(const Transform& o) { *this = o; }
	Transform& operator=(const Transform& o)
	{
		m_eType	= o.m_eType;
		m_A		= o.m_A;
		m_B		= o.m_B;
		return *this;
	}
	void Do(QPointF& o) const	// Transform the passed in point
	{
		qreal dRadians(0), C(0), S(0);
		const qreal x = o.x();	// Take a copy (not a reference)
		const qreal y = o.y();	// Take a copy (not a reference)
		switch( m_eType )
		{
			case TRANSFORM::SCALE:		o.setX(x * m_A);	o.setY(y * m_B);	return;
			case TRANSFORM::TRANSLATE:	o.setX(x + m_A);	o.setY(y + m_B);	return;
			case TRANSFORM::ROTATE:		dRadians = m_A * RADIANS_PER_DEGREE;
										C = cos(dRadians);	S = sin(dRadians);
										o.setX(x*C - y*S);	o.setY(x*S + y*C);	return;
			default:					assert(m_eType == TRANSFORM::NONE);		return;
		}
	}
	const TRANSFORM& GetType() const { return m_eType; }
private:
	TRANSFORM	m_eType	= TRANSFORM::TRANSLATE;	// Transform type
	qreal		m_A		= 0;					// Parameter 1
	qreal		m_B		= 0;					// Parameter 2
};