From 1bfb73b87798f925c4cf1798b0bdceaced4ec6a6 Mon Sep 17 00:00:00 2001 From: Vadim Zeitlin Date: Fri, 10 Feb 2006 00:01:19 +0000 Subject: [PATCH] added wxRect::CentreIn() git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@37435 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- docs/latex/wx/rect.tex | 13 +++++++++++++ include/wx/gdicmn.h | 14 ++++++++++++++ tests/geometry/rect.cpp | 28 ++++++++++++++++++++++++++++ 3 files changed, 55 insertions(+) diff --git a/docs/latex/wx/rect.tex b/docs/latex/wx/rect.tex index 30cba05bf7..4046c7207a 100644 --- a/docs/latex/wx/rect.tex +++ b/docs/latex/wx/rect.tex @@ -68,6 +68,19 @@ Width member. Height member. +\membersection{wxRect::CentreIn}\label{wxrectcentrein} + +\constfunc{wxRect}{CentreIn}{\param{const wxRect\& }{r}, \param{int }{dir = wxBOTH}} + +\constfunc{wxRect}{CenterIn}{\param{const wxRect\& }{r}, \param{int }{dir = wxBOTH}} + +Returns the rectangle having the same size as this one but centered relatively +to the given rectangle \arg{r}. By default, rectangle is centred in both +directions but if \arg{dir} includes only \texttt{wxVERTICAL} or only +\texttt{wxHORIZONTAL} flag, then it is only centered in this direction while +the other component of its position remains unchanged. + + \membersection{wxRect::Deflate}\label{wxrectdeflate} \func{void}{Deflate}{\param{wxCoord }{dx}, \param{wxCoord }{dy}} diff --git a/include/wx/gdicmn.h b/include/wx/gdicmn.h index d38fe44b93..b6faf8900d 100644 --- a/include/wx/gdicmn.h +++ b/include/wx/gdicmn.h @@ -428,6 +428,20 @@ public: } + // centre this rectangle in the given (usually, but not necessarily, + // larger) one + wxRect CentreIn(const wxRect& r, int dir = wxBOTH) const + { + return wxRect(dir & wxHORIZONTAL ? r.x + (r.width - width)/2 : x, + dir & wxVERTICAL ? r.y + (r.height - height)/2 : y, + width, height); + } + + wxRect CenterIn(const wxRect& r, int dir = wxBOTH) const + { + return CentreIn(r, dir); + } + public: int x, y, width, height; }; diff --git a/tests/geometry/rect.cpp b/tests/geometry/rect.cpp index c7d73971f6..cb196373ce 100644 --- a/tests/geometry/rect.cpp +++ b/tests/geometry/rect.cpp @@ -21,6 +21,21 @@ #include "wx/gdicmn.h" #endif // WX_PRECOMP +#include "wx/iosfwrap.h" + +// ---------------------------------------------------------------------------- +// helper functions +// ---------------------------------------------------------------------------- + +// this operator is needed to use CPPUNIT_ASSERT_EQUAL with wxRects +wxSTD ostream& operator<<(wxSTD ostream& os, const wxRect& r) +{ + os << "{" + << r.x << ", " << r.y << ", " << r.width << ", " << r.height + << "}"; + return os; +} + // ---------------------------------------------------------------------------- // test class // ---------------------------------------------------------------------------- @@ -32,11 +47,13 @@ public: private: CPPUNIT_TEST_SUITE( RectTestCase ); + CPPUNIT_TEST( CentreIn ); CPPUNIT_TEST( InflateDeflate ); CPPUNIT_TEST( Operators ); CPPUNIT_TEST( Union ); CPPUNIT_TEST_SUITE_END(); + void CentreIn(); void InflateDeflate(); void Operators(); void Union(); @@ -50,6 +67,17 @@ CPPUNIT_TEST_SUITE_REGISTRATION( RectTestCase ); // also include in it's own registry so that these tests can be run alone CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( RectTestCase, "RectTestCase" ); +void RectTestCase::CentreIn() +{ + typedef wxRect R; + + CPPUNIT_ASSERT_EQUAL( R(45, 45, 10, 10), + R(0, 0, 10, 10).CentreIn(R(0, 0, 100, 100))); + + CPPUNIT_ASSERT_EQUAL( R(-5, -5, 20, 20), + R(0, 0, 20, 20).CentreIn(R(0, 0, 10, 10))); +} + void RectTestCase::InflateDeflate() { // This is the rectangle from the example in the documentation of wxRect::Inflate(). -- 2.45.2