2017-06-12 15:35:22 +03:00
|
|
|
//
|
|
|
|
// "$Id$"
|
|
|
|
//
|
|
|
|
// Fl_Rect header file for the Fast Light Tool Kit (FLTK).
|
|
|
|
//
|
2018-04-10 21:41:34 +03:00
|
|
|
// Copyright 1998-2018 by Bill Spitzak and others.
|
2017-06-12 15:35:22 +03:00
|
|
|
//
|
|
|
|
// This library is free software. Distribution and use rights are outlined in
|
|
|
|
// the file "COPYING" which should have been included with this file. If this
|
|
|
|
// file is missing or damaged, see the license at:
|
|
|
|
//
|
|
|
|
// http://www.fltk.org/COPYING.php
|
|
|
|
//
|
|
|
|
// Please report all bugs and problems on the following page:
|
|
|
|
//
|
|
|
|
// http://www.fltk.org/str.php
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef Fl_Rect_H
|
|
|
|
#define Fl_Rect_H
|
|
|
|
|
|
|
|
#include <FL/Fl_Widget.H> // for c'tor based on Fl_Widget
|
|
|
|
|
|
|
|
/**
|
|
|
|
Rectangle with standard FLTK coordinates (X, Y, W, H).
|
|
|
|
|
|
|
|
This may be used internally, for overloaded widget contructors and other
|
|
|
|
overloaded methods like fl_measure(), fl_text_extents(), fl_rect(),
|
|
|
|
fl_rectf(), and maybe more.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class FL_EXPORT Fl_Rect {
|
|
|
|
|
|
|
|
int x_;
|
|
|
|
int y_;
|
|
|
|
int w_;
|
|
|
|
int h_;
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/** The default constructor creates an empty rectangle (x = y = w = h = 0). */
|
|
|
|
Fl_Rect()
|
2018-03-12 15:57:28 +03:00
|
|
|
: x_(0), y_(0), w_(0), h_(0) {}
|
2017-06-12 15:35:22 +03:00
|
|
|
|
|
|
|
/** This constructor creates a rectangle with x = y = 0 and
|
|
|
|
the given width and height. */
|
|
|
|
Fl_Rect(int W, int H)
|
2018-03-12 15:57:28 +03:00
|
|
|
: x_(0), y_(0), w_(W), h_(H) {}
|
2017-06-12 15:35:22 +03:00
|
|
|
|
|
|
|
/** This constructor creates a rectangle with the given x,y coordinates
|
|
|
|
and the given width and height. */
|
|
|
|
Fl_Rect(int X, int Y, int W, int H)
|
2018-03-12 15:57:28 +03:00
|
|
|
: x_(X), y_(Y), w_(W), h_(H) {}
|
2017-06-12 15:35:22 +03:00
|
|
|
|
2018-03-12 23:54:27 +03:00
|
|
|
/** This constructor creates a rectangle based on a widget's position and size. */
|
2017-06-12 15:35:22 +03:00
|
|
|
Fl_Rect (const Fl_Widget& widget)
|
2018-03-12 15:57:28 +03:00
|
|
|
: x_(widget.x()), y_(widget.y()), w_(widget.w()), h_(widget.h()) {}
|
2017-06-12 15:35:22 +03:00
|
|
|
|
2018-03-12 23:54:27 +03:00
|
|
|
/** This constructor creates a rectangle based on a widget's position and size. */
|
2017-06-12 15:35:22 +03:00
|
|
|
Fl_Rect (const Fl_Widget* const widget)
|
2018-03-12 15:57:28 +03:00
|
|
|
: x_(widget->x()), y_(widget->y()), w_(widget->w()), h_(widget->h()) {}
|
2018-03-10 03:46:12 +03:00
|
|
|
|
2017-06-12 15:35:22 +03:00
|
|
|
int x() const { return x_; } ///< gets the x coordinate (left edge)
|
|
|
|
int y() const { return y_; } ///< gets the y coordinate (top edge)
|
|
|
|
int w() const { return w_; } ///< gets the width
|
|
|
|
int h() const { return h_; } ///< gets the height
|
|
|
|
|
2018-04-10 21:41:34 +03:00
|
|
|
/** gets the right edge (x + w).
|
|
|
|
\note r() and b() are coordinates \b outside the area of the rectangle.
|
|
|
|
*/
|
|
|
|
int r() const { return x_ + w_; }
|
|
|
|
/** gets the bottom edge (y + h).
|
|
|
|
\note r() and b() are coordinates \b outside the area of the rectangle.
|
|
|
|
*/
|
|
|
|
int b() const { return y_ + h_; }
|
2017-06-12 15:35:22 +03:00
|
|
|
|
|
|
|
void x(int X) { x_ = X; } ///< sets the x coordinate (left edge)
|
|
|
|
void y(int Y) { y_ = Y; } ///< sets the y coordinate (top edge)
|
|
|
|
void w(int W) { w_ = W; } ///< sets the width
|
|
|
|
void h(int H) { h_ = H; } ///< sets the height
|
|
|
|
|
|
|
|
}; // class Fl_Rect
|
|
|
|
|
|
|
|
#endif // Fl_Rect_H
|
|
|
|
|
|
|
|
//
|
|
|
|
// End of "$Id$".
|
|
|
|
//
|