File: SMatrix.h

package info (click to toggle)
yudit 3.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 18,472 kB
  • sloc: cpp: 76,344; perl: 5,630; makefile: 989; ansic: 823; sh: 441
file content (58 lines) | stat: -rw-r--r-- 1,767 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
/** 
 *  Yudit Unicode Editor Source File
 *
 *  GNU Copyright (C) 1997-2023  Gaspar Sinai <gaspar@yudit.org>  
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License, version 2,
 *  dated June 1991. See file COPYYING for details.
 *
 *  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, write to the Free Software
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */
 
#ifndef SMatrix_h
#define SMatrix_h

#include "stoolkit/SBinVector.h"
/**
 * @author: Gaspar Sinai <gaspar@yudit.org>
 * @version: 2000-04-23
 */

/*
 * Matrices and the like
 */
class SS_Matrix2D
{
public:
  SS_Matrix2D(void);
  SS_Matrix2D(const SS_Matrix2D& m);
  ~SS_Matrix2D();
  SS_Matrix2D operator= (const SS_Matrix2D& m);
  friend bool operator== (const SS_Matrix2D& m1, const SS_Matrix2D& m2);
  friend bool operator< (const SS_Matrix2D& m1, const SS_Matrix2D& m2);
  friend bool operator> (const SS_Matrix2D& m1, const SS_Matrix2D& m2);
  SS_Matrix2D operator* (const SS_Matrix2D& m1) const;
  void rotate (double angle);
  void translate (double x, double y);
  SS_Matrix2D invert() const;

  double toX(double x, double y) const;
  double toY(double x, double y) const;

  void scale (double x, double y);
  double x0; double y0; double t0;
  double x1; double y1; double t1;
  double x2; double y2; double t2;
};

typedef SBinVector<SS_Matrix2D> SS_MatrixStack;

#endif /* SMatrix_h */