move Rect and PointerAssassin into the toolkit
This commit is contained in:
parent
fa8cefef63
commit
37e5600768
8 changed files with 184 additions and 7 deletions
|
@ -5,7 +5,7 @@ INCLUDES= -I../src
|
||||||
noinst_LIBRARIES=libotk.a
|
noinst_LIBRARIES=libotk.a
|
||||||
|
|
||||||
libotk_a_SOURCES= color.cc display.cc font.cc gccache.cc image.cc \
|
libotk_a_SOURCES= color.cc display.cc font.cc gccache.cc image.cc \
|
||||||
imagecontrol.cc texture.cc
|
imagecontrol.cc rect.cc texture.cc
|
||||||
|
|
||||||
MAINTAINERCLEANFILES= Makefile.in
|
MAINTAINERCLEANFILES= Makefile.in
|
||||||
|
|
||||||
|
|
15
otk/assassin.hh
Normal file
15
otk/assassin.hh
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef __assassin_hh
|
||||||
|
#define __assassin_hh
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
struct PointerAssassin {
|
||||||
|
template<typename T>
|
||||||
|
inline void operator()(const T ptr) const {
|
||||||
|
delete ptr;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // __assassin_hh
|
|
@ -10,7 +10,7 @@ extern "C" {
|
||||||
|
|
||||||
#include "gccache.hh"
|
#include "gccache.hh"
|
||||||
#include "color.hh"
|
#include "color.hh"
|
||||||
#include "util.hh"
|
#include "assassin.hh"
|
||||||
#include "screeninfo.hh"
|
#include "screeninfo.hh"
|
||||||
|
|
||||||
namespace otk {
|
namespace otk {
|
||||||
|
|
|
@ -9,9 +9,9 @@ extern "C" {
|
||||||
|
|
||||||
#include <list>
|
#include <list>
|
||||||
|
|
||||||
#include "timer.hh"
|
|
||||||
#include "color.hh"
|
#include "color.hh"
|
||||||
#include "screeninfo.hh"
|
#include "screeninfo.hh"
|
||||||
|
#include "src/timer.hh"
|
||||||
|
|
||||||
namespace otk {
|
namespace otk {
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class BImageControl : public TimeoutHandler {
|
class BImageControl : public ob::TimeoutHandler {
|
||||||
public:
|
public:
|
||||||
struct CachedImage {
|
struct CachedImage {
|
||||||
Pixmap pixmap;
|
Pixmap pixmap;
|
||||||
|
@ -116,7 +116,7 @@ public:
|
||||||
private:
|
private:
|
||||||
bool dither;
|
bool dither;
|
||||||
const ScreenInfo *screeninfo;
|
const ScreenInfo *screeninfo;
|
||||||
BTimer *timer;
|
ob::BTimer *timer;
|
||||||
|
|
||||||
Colormap colormap;
|
Colormap colormap;
|
||||||
|
|
||||||
|
|
|
@ -58,7 +58,7 @@ BImageControl::BImageControl(const ScreenInfo *scrn,
|
||||||
timer->setTimeout(cache_timeout);
|
timer->setTimeout(cache_timeout);
|
||||||
timer->start();*/
|
timer->start();*/
|
||||||
} else {
|
} else {
|
||||||
timer = (BTimer *) 0;
|
timer = (ob::BTimer *) 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
colors = (XColor *) 0;
|
colors = (XColor *) 0;
|
||||||
|
|
96
otk/rect.cc
Normal file
96
otk/rect.cc
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
#include "rect.hh"
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
void Rect::setX(int x) {
|
||||||
|
_x2 += x - _x1;
|
||||||
|
_x1 = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setY(int y)
|
||||||
|
{
|
||||||
|
_y2 += y - _y1;
|
||||||
|
_y1 = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setPos(int x, int y) {
|
||||||
|
_x2 += x - _x1;
|
||||||
|
_x1 = x;
|
||||||
|
_y2 += y - _y1;
|
||||||
|
_y1 = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setWidth(unsigned int w) {
|
||||||
|
_x2 = w + _x1 - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setHeight(unsigned int h) {
|
||||||
|
_y2 = h + _y1 - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setSize(unsigned int w, unsigned int h) {
|
||||||
|
_x2 = w + _x1 - 1;
|
||||||
|
_y2 = h + _y1 - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setRect(int x, int y, unsigned int w, unsigned int h) {
|
||||||
|
*this = Rect(x, y, w, h);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Rect::setCoords(int l, int t, int r, int b) {
|
||||||
|
_x1 = l;
|
||||||
|
_y1 = t;
|
||||||
|
_x2 = r;
|
||||||
|
_y2 = b;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Rect Rect::operator|(const Rect &a) const {
|
||||||
|
Rect b;
|
||||||
|
|
||||||
|
b._x1 = std::min(_x1, a._x1);
|
||||||
|
b._y1 = std::min(_y1, a._y1);
|
||||||
|
b._x2 = std::max(_x2, a._x2);
|
||||||
|
b._y2 = std::max(_y2, a._y2);
|
||||||
|
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Rect Rect::operator&(const Rect &a) const {
|
||||||
|
Rect b;
|
||||||
|
|
||||||
|
b._x1 = std::max(_x1, a._x1);
|
||||||
|
b._y1 = std::max(_y1, a._y1);
|
||||||
|
b._x2 = std::min(_x2, a._x2);
|
||||||
|
b._y2 = std::min(_y2, a._y2);
|
||||||
|
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Rect::intersects(const Rect &a) const {
|
||||||
|
return std::max(_x1, a._x1) <= std::min(_x2, a._x2) &&
|
||||||
|
std::max(_y1, a._y1) <= std::min(_y2, a._y2);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Rect::contains(int x, int y) const {
|
||||||
|
return x >= _x1 && x <= _x2 &&
|
||||||
|
y >= _y1 && y <= _y2;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Rect::contains(const Rect& a) const {
|
||||||
|
return a._x1 >= _x1 && a._x2 <= _x2 &&
|
||||||
|
a._y1 >= _y1 && a._y2 <= _y2;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
66
otk/rect.hh
Normal file
66
otk/rect.hh
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
// -*- mode: C++; indent-tabs-mode: nil; -*-
|
||||||
|
#ifndef __rect_hh
|
||||||
|
#define __rect_hh
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
namespace otk {
|
||||||
|
|
||||||
|
class Rect {
|
||||||
|
public:
|
||||||
|
inline Rect(void) : _x1(0), _y1(0), _x2(0), _y2(0) { }
|
||||||
|
inline Rect(int __x, int __y, unsigned int __w, unsigned int __h)
|
||||||
|
: _x1(__x), _y1(__y), _x2(__w + __x - 1), _y2(__h + __y - 1) { }
|
||||||
|
inline explicit Rect(const XRectangle& xrect)
|
||||||
|
: _x1(xrect.x), _y1(xrect.y), _x2(xrect.width + xrect.x - 1),
|
||||||
|
_y2(xrect.height + xrect.y - 1) { }
|
||||||
|
|
||||||
|
inline int left(void) const { return _x1; }
|
||||||
|
inline int top(void) const { return _y1; }
|
||||||
|
inline int right(void) const { return _x2; }
|
||||||
|
inline int bottom(void) const { return _y2; }
|
||||||
|
|
||||||
|
inline int x(void) const { return _x1; }
|
||||||
|
inline int y(void) const { return _y1; }
|
||||||
|
void setX(int __x);
|
||||||
|
void setY(int __y);
|
||||||
|
void setPos(int __x, int __y);
|
||||||
|
|
||||||
|
inline unsigned int width(void) const { return _x2 - _x1 + 1; }
|
||||||
|
inline unsigned int height(void) const { return _y2 - _y1 + 1; }
|
||||||
|
void setWidth(unsigned int __w);
|
||||||
|
void setHeight(unsigned int __h);
|
||||||
|
void setSize(unsigned int __w, unsigned int __h);
|
||||||
|
|
||||||
|
void setRect(int __x, int __y, unsigned int __w, unsigned int __h);
|
||||||
|
|
||||||
|
void setCoords(int __l, int __t, int __r, int __b);
|
||||||
|
|
||||||
|
inline bool operator==(const Rect &a)
|
||||||
|
{ return _x1 == a._x1 && _y1 == a._y1 && _x2 == a._x2 && _y2 == a._y2; }
|
||||||
|
inline bool operator!=(const Rect &a) { return ! operator==(a); }
|
||||||
|
|
||||||
|
Rect operator|(const Rect &a) const;
|
||||||
|
Rect operator&(const Rect &a) const;
|
||||||
|
inline Rect &operator|=(const Rect &a) { *this = *this | a; return *this; }
|
||||||
|
inline Rect &operator&=(const Rect &a) { *this = *this & a; return *this; }
|
||||||
|
|
||||||
|
inline bool valid(void) const { return _x2 > _x1 && _y2 > _y1; }
|
||||||
|
|
||||||
|
bool intersects(const Rect &a) const;
|
||||||
|
bool contains(int __x, int __y) const;
|
||||||
|
bool contains(const Rect &a) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
int _x1, _y1, _x2, _y2;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef std::vector<Rect> RectList;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // __rect_hh
|
|
@ -2,7 +2,7 @@
|
||||||
#ifndef __screeninfo_hh
|
#ifndef __screeninfo_hh
|
||||||
#define __screeninfo_hh
|
#define __screeninfo_hh
|
||||||
|
|
||||||
#include "util.hh"
|
#include "rect.hh"
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
|
|
Loading…
Reference in a new issue