You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kmplayer/src/kmplayertypes.h

301 lines
9.9 KiB

/*
* Copyright (C) 2006 Koos Vriezen <koos.vriezen@gmail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef _KMPLAYER_TYPES_H_
#define _KMPLAYER_TYPES_H_
#include <stdint.h>
#include "kmplayer_def.h"
#include "triestring.h"
namespace KMPlayer {
/**
* Type meant for screen coordinates
*/
class KMPLAYER_NO_EXPORT Single {
int value;
friend Single operator + (const Single s1, const Single s2);
friend Single operator - (const Single s1, const Single s2);
friend Single operator * (const Single s1, const Single s2);
friend Single operator / (const Single s1, const Single s2);
friend Single operator + (const Single s1, const int i);
friend Single operator - (const Single s1, const int i);
friend float operator * (const Single s, const float f);
friend double operator * (const Single s, const double f);
friend Single operator * (const int i, const Single s);
friend float operator * (const float f, const Single s);
friend double operator * (const double d, const Single s);
friend Single operator / (const Single s, const int i);
friend float operator / (const Single s, const float f);
friend double operator / (const Single s, const double d);
friend double operator / (const double d, const Single s);
friend bool operator > (const Single s1, const Single s2);
friend bool operator > (const Single s, const int i);
friend bool operator > (const int i, const Single s);
friend bool operator >= (const Single s1, const Single s2);
friend bool operator == (const Single s1, const Single s2);
friend bool operator != (const Single s1, const Single s2);
friend bool operator < (const Single s1, const Single s2);
friend bool operator < (const Single s, const int i);
friend bool operator < (const int i, const Single s);
friend bool operator <= (const Single s1, const Single s2);
friend bool operator <= (const Single s, const int i);
#ifdef _KDEBUG_H_
friend kdbgstream & operator << (kdbgstream &, Single s);
friend kndbgstream & operator << (kndbgstream &, Single s);
#endif
friend Single operator - (const Single s);
public:
Single () : value (0) {}
Single (const int v) : value (v << 8) {}
Single (const float v) : value (int (256 * v)) {}
Single (const double v) : value (int (256 * v)) {}
Single & operator = (const Single s) { value = s.value; return *this; }
Single & operator = (const int v) { value = v << 8; return *this; }
Single & operator = (const float v) { value = int (256 * v); return *this; }
Single & operator = (const double v) { value = int(256 * v); return *this; }
Single & operator += (const Single s) { value += s.value; return *this; }
Single & operator += (const int i) { value += (i << 8); return *this; }
Single & operator -= (const Single s) { value -= s.value; return *this; }
Single & operator -= (const int i) { value -= (i << 8); return *this; }
Single & operator *= (const Single s);
Single & operator *= (const float f) { value = int(value*f); return *this; }
Single & operator /= (const int i) { value /= i; return *this; }
Single & operator /= (const float f);
operator int () const { return value >> 8; }
operator double () const { return 1.0 * value / 256; }
};
/** a b 0
* Matrix for coordinate transforms c d 0
* tx ty 1 */
class KMPLAYER_NO_EXPORT Matrix {
friend class SizeEvent;
float a, b, c, d;
Single tx, ty;
public:
Matrix ();
Matrix (const Matrix & matrix);
Matrix (Single xoff, Single yoff, float xscale, float yscale);
void getXY (Single & x, Single & y) const;
void getXYWH (Single & x, Single & y, Single & w, Single & h) const;
void invXYWH (Single & x, Single & y, Single & w, Single & h) const;
void transform (const Matrix & matrix);
void scale (float sx, float sy);
void translate (Single x, Single y);
// void rotate (float phi); // add this when needed
};
class KMPLAYER_NO_EXPORT SRect {
Single _x, _y, _w, _h;
#ifdef _KDEBUG_H_
friend kdbgstream & operator << (kdbgstream &, const SRect &s);
friend kndbgstream & operator << (kndbgstream &, const SRect &s);
#endif
public:
SRect () {}
SRect (Single a, Single b, Single w, Single h)
: _x (a), _y (b), _w (w), _h (h) {}
Single x () const { return _x; }
Single y () const { return _y; }
Single width () const { return _w; }
Single height () const { return _h; }
SRect unite (const SRect & r) const;
SRect intersect (const SRect & r) const;
bool isValid () const { return _w >= Single (0) && _h >= Single (0); }
bool operator == (const SRect & r) const;
bool operator != (const SRect & r) const;
};
class KMPLAYER_NO_EXPORT IRect {
public:
int x, y, w, h;
IRect ()
: x (0), y (0), w (0), h (0) {}
explicit IRect (const SRect r)
: x (r.x ()), y (r.y ()), w (r.width ()), h (r.height ()) {}
IRect (int a, int b, int c, int d)
: x (a), y (b), w (c), h (d) {}
IRect unite (const IRect & r) const;
IRect intersect (const IRect & r) const;
bool isValid () const { return w >= 0 && h >= 0; }
bool isEmpty () const { return w < 0 || h < 0; }
};
//-----------------------------------------------------------------------------
#ifdef _KDEBUG_H_
inline kdbgstream & operator << (kdbgstream & dbg, Single s) {
dbg << (double) (s);
return dbg;
}
inline kndbgstream & operator << (kndbgstream & dbg, Single) { return dbg; }
inline kdbgstream & operator << (kdbgstream & dbg, const SRect &r) {
dbg << "SRect(x=" << r._x << " y=" << r._y << " w=" << r._w << " h=" << r._h << ")";
return dbg;
}
inline kndbgstream & operator << (kndbgstream &d, const SRect&) { return d; }
inline kdbgstream & operator << (kdbgstream & dbg, const IRect &r) {
dbg << "IRect(x=" << r.x << " y=" << r.y << " w=" << r.w << " h=" << r.h << ")";
return dbg;
}
inline kndbgstream & operator << (kndbgstream &d, const IRect&) { return d; }
#endif
inline Single & Single::operator *= (const Single s) {
value = (((int64_t)value) * s.value) >> 8;
return *this;
}
inline Single & Single::operator /= (const float f) {
value = (int) (value / f);
return *this;
}
inline Single operator + (const Single s1, const Single s2) {
Single s;
s.value = s1.value + s2.value;
return s;
}
inline Single operator - (const Single s1, const Single s2) {
Single s;
s.value = s1.value - s2.value;
return s;
}
inline Single operator * (const Single s1, const Single s2) {
Single s;
s.value = (((int64_t)s1.value) * s2.value) >> 8;
return s;
}
inline Single operator / (const Single s1, const Single s2) {
Single s;
s.value = ((int64_t)s1.value << 8) / s2.value;
return s;
}
inline Single operator + (const Single s, const int i) {
return s + Single (i);
}
inline Single operator - (const Single s, const int i) {
return s - Single (i);
}
inline Single operator * (const int i, const Single s) {
Single s1;
s1.value = s.value * i;
return s1;
}
inline Single operator * (const Single s, const int i) {
return i * s;
}
inline float operator * (const Single s, const float f) {
return s.value * f / 256;
}
inline double operator * (const Single s, const double d) {
return s.value * d / 256;
}
inline float operator * (const float f, const Single s) {
return s.value * f / 256;
}
inline double operator * (const double d, const Single s) {
return s.value * d / 256;
}
inline Single operator / (const Single s, const int i) {
Single s1;
s1.value = s.value / i;
return s1;
}
inline float operator / (const Single s, const float f) {
return (s.value / f ) / 256;
}
inline double operator / (const Single s, const double d) {
return (s.value / d ) / 256;
}
inline double operator / (const double d, const Single s) {
return (d * 256 / s.value);
}
inline bool
operator > (const Single s1, const Single s2) { return s1.value > s2.value; }
inline bool
operator > (const Single s, const int i) { return s > Single (i); }
inline bool
operator > (const int i, const Single s) { return Single (i) > s; }
inline bool
operator >= (const Single s1, const Single s2) { return s1.value >= s2.value; }
inline bool
operator == (const Single s1, const Single s2) { return s1.value == s2.value; }
inline bool
operator != (const Single s1, const Single s2) { return s1.value != s2.value; }
inline bool
operator < (const Single s1, const Single s2) { return s1.value < s2.value; }
inline bool
operator < (const Single s, const int i) { return s < Single (i); }
inline bool
operator < (const int i, const Single s) { return Single (i) < s; }
inline bool
operator <= (const Single s1, const Single s2) { return s1.value <= s2.value; }
inline bool
operator <= (const Single s, const int i) { return s <= Single (i); }
inline Single operator - (const Single s) {
Single s1;
s1.value = -s.value;
return s1;
}
//-----------------------------------------------------------------------------
inline bool SRect::operator == (const SRect & r) const {
return _x == r._x && _y == r._y && _w == r._w && _h == r._h;
}
inline bool SRect::operator != (const SRect & r) const { return !(*this == r); }
} // KMPlayer namespace
#endif //_KMPLAYER_TYPES_H_