basic3dborder.cpp
来自「这是VCF框架的代码」· C++ 代码 · 共 305 行
CPP
305 行
//Basic3DBorder.cpp/*Copyright 2000-2004 The VCF Project.Please see License.txt in the top level directorywhere you installed the VCF.*/#include "vcf/ApplicationKit/ApplicationKit.h"using namespace VCF;Basic3DBorder::Basic3DBorder(): inverted_(false){}Basic3DBorder::Basic3DBorder( bool inverted ): inverted_(inverted){}Basic3DBorder::Basic3DBorder( Component* owner ): Border( owner ), inverted_(false){}Basic3DBorder::~Basic3DBorder(){}Rect Basic3DBorder::getClientRect( Rect* initialBounds, Control* control ){ Rect result = *initialBounds; result.inflate( -2.0, -2.0 ); return result;}void Basic3DBorder::paint( Rect* bounds, GraphicsContext* context ){ if ( NULL != bounds ){ Color* hilight = GraphicsToolkit::getSystemColor( SYSCOLOR_HIGHLIGHT ); Color* shadow = GraphicsToolkit::getSystemColor( SYSCOLOR_SHADOW ); Color* face = GraphicsToolkit::getSystemColor( SYSCOLOR_FACE ); if ( true == inverted_ ){ //outside left and top context->moveTo( bounds->left_, bounds->bottom_-2. ); context->lineTo( bounds->left_, bounds->top_ ); context->lineTo( bounds->right_-1.0, bounds->top_ ); context->setColor( shadow ); context->strokePath(); //inside left and top context->moveTo( bounds->left_+1., bounds->bottom_-2. ); context->lineTo( bounds->left_+1., bounds->top_+1. ); context->lineTo( bounds->right_-2., bounds->top_+1. ); context->setColor( &Color(181.0,181.0,181.0) );// prob. should be 3DdarkShadow context->strokePath(); //outside bottom and right context->moveTo( bounds->left_, bounds->bottom_-1. ); context->lineTo( bounds->right_-1., bounds->bottom_-1. ); context->lineTo( bounds->right_-1., bounds->top_-1. ); context->setColor( hilight ); context->strokePath(); //inside bottom and right context->moveTo( bounds->left_+1., bounds->bottom_-2. ); context->lineTo( bounds->right_-2., bounds->bottom_-2. ); context->lineTo( bounds->right_-2., bounds->top_ ); context->setColor( face ); context->strokePath(); } else { //outside left and top context->moveTo( bounds->left_, bounds->bottom_-2. ); context->lineTo( bounds->left_, bounds->top_ ); context->lineTo( bounds->right_-1.0, bounds->top_ ); context->setColor( hilight ); context->strokePath(); //inside left and top context->moveTo( bounds->left_+1., bounds->bottom_-2. ); context->lineTo( bounds->left_+1., bounds->top_+1. ); context->lineTo( bounds->right_-2., bounds->top_+1. ); context->setColor( face ); context->strokePath(); //outside bottom and right context->moveTo( bounds->left_, bounds->bottom_-1. ); context->lineTo( bounds->right_-1., bounds->bottom_-1. ); context->lineTo( bounds->right_-1., bounds->top_-1. ); context->setColor( &Color(181.0,181.0,181.0) ); context->strokePath(); //inside bottom and right context->moveTo( bounds->left_+1., bounds->bottom_-2. ); context->lineTo( bounds->right_-2., bounds->bottom_-2. ); context->lineTo( bounds->right_-2., bounds->top_ ); context->setColor( shadow ); context->strokePath(); /* context->rectangle( bounds->left_, bounds->top_, bounds->right_, bounds->bottom_ ); context->setColor( face ); context->fillPath(); context->moveTo( bounds->left_+1, bounds->bottom_-2 ); context->lineTo( bounds->left_+1, bounds->top_+1 ); context->lineTo( bounds->right_-2, bounds->top_+1 ); context->setColor( hilight ); context->strokePath(); context->moveTo( bounds->right_-2, bounds->top_+1 ); context->lineTo( bounds->right_-2, bounds->bottom_-2 ); context->lineTo( bounds->left_+1, bounds->bottom_-2 ); context->setColor( shadow ); context->strokePath(); context->moveTo( bounds->right_-1, bounds->top_ ); context->lineTo( bounds->right_-1, bounds->bottom_-1 ); context->lineTo( bounds->left_, bounds->bottom_-1 ); context->setColor( &Color(0.0,0.0,0.0) ); context->strokePath(); */ } }}void Basic3DBorder::paint( Control* component, GraphicsContext* context ){ if ( NULL == component ){ //throw exception } Rect bounds = component->getClientBounds(false); if ( !bounds.isEmpty() ) { paint( &bounds, context ); }}/***CVS Log info*$Log$*Revision 1.4 2005/07/09 23:14:51 ddiego*merging in changes from devmain-0-6-7 branch.**Revision 1.3.2.1 2005/03/06 22:50:58 ddiego*overhaul of RTTI macros. this includes changes to various examples to accommadate the new changes.**Revision 1.3 2004/12/01 04:31:19 ddiego*merged over devmain-0-6-6 code. Marcello did a kick ass job*of fixing a nasty bug (1074768VCF application slows down modal dialogs.)*that he found. Many, many thanks for this Marcello.**Revision 1.2.2.1 2004/08/22 19:16:59 dougtinkham*changed paint of left and top border edges for raised edges.**Revision 1.2 2004/08/07 02:49:05 ddiego*merged in the devmain-0-6-5 branch to stable**Revision 1.1.2.5 2004/07/15 04:27:14 ddiego*more updates for edit nc client painting**Revision 1.1.2.4 2004/07/14 21:54:41 ddiego*attempts to fix problem with borders and drawing on common controls.*Sort of works on editor control. There is a subtle repaint problem in painting*damaged portions of the control.**Revision 1.1.2.3 2004/07/07 22:37:30 dougtinkham*added inverstion to give border a sunken appearrance.**Revision 1.1.2.2 2004/04/29 03:43:12 marcelloptr*reformatting of source files: macros and csvlog and copyright sections**Revision 1.1.2.1 2004/04/28 00:28:13 ddiego*migration towards new directory structure**Revision 1.16 2004/04/03 15:48:46 ddiego*Merged over code from the 0-6-3 branch.**Revision 1.15.2.1 2004/02/24 01:42:44 ddiego*initial OSX ApplicationKit port checkin**Revision 1.15 2003/12/18 05:16:01 ddiego*merge from devmain-0-6-2 branch into the stable branch**Revision 1.14.2.1 2003/08/18 19:52:38 ddiego*changed the Container from being a class you derive from to a separate*intance that is created and assigned dynamically to any Control.**Revision 1.14 2003/08/09 02:56:45 ddiego*merge over from the devmain-0-6-1 branch*Changes*Features:*-Added additional implementation to better support the MVC architecture in*the VCF**-Added a Document/View architecure that is similar to MFC's or NextSteps's*Doc/View architectures**-Integrated the Anti Grain Graphics library into the GraphicsKit. There is*now basic support for it in terms of drawing vector shapes*(fills and strokes). Image support will come in the next release**-Added several documented graphics tutorials**Bugfixes:**[ 775744 ] wrong buttons on a dialog*[ 585239 ] Painting weirdness in a modal dialog ?*[ 585238 ] Modal dialog which makes a modal Dialog*[ 509004 ] Opening a modal Dialog causes flicker*[ 524878 ] onDropped not called for MLTcontrol**Plus an issue with some focus and getting the right popup window to activate*has also been fixed**Revision 1.13.2.1 2003/07/24 04:10:44 ddiego*added fixes for the following tasks:*Task #82279 ApplicationKit: add static methods to singleton objects*Task #82277 FoundationKit: add static methods to singleton objects*this required a bunch of changes in terms of getting rid of older style code**Revision 1.13 2003/05/17 20:37:19 ddiego*this is the checkin for the 0.6.1 release - represents the merge over from*the devmain-0-6-0 branch plus a few minor bug fixes**Revision 1.12.2.3 2003/04/17 04:29:50 ddiego*updated scintilla, added gtk support for the application kit, with stubs*for the basic peers.**Revision 1.12.2.2 2003/03/23 03:23:55 marcelloptr*3 empty lines at the end of the files**Revision 1.12.2.1 2003/03/12 03:11:59 ddiego*switched all member variable that used the "m_"<name> prefix to* <name>"_" suffix nameing standard.*Also changed all vcf builder files to accomadate this.*Changes were made to the Stream classes to NOT multiple inheritance and to*be a little more correct. Changes include breaking the FileStream into two*distinct classes, one for input and one for output.**Revision 1.12 2003/02/26 04:30:46 ddiego*merge of code in the devmain-0-5-9 branch into the current tree.*most additions are in the area of the current linux port, but the major*addition to this release is the addition of a Condition class (currently*still under development) and the change over to using the Delegate class*exclusively from the older event handler macros.**Revision 1.11.2.2 2002/12/28 01:56:21 marcelloptr*Improved macros for automatic import/export of libraries. - Warning fixes. - Other Minor Changes.**Revision 1.11.2.1 2002/12/27 23:04:46 marcelloptr*Improved macros for automatic import/export of libraries. - Warning fixes. - Other Minor Changes.**Revision 1.11 2002/11/18 00:46:08 ddiego*this is the merge over of all the bug fixes and features (mostly*VCF Builder stuff) from the devmain-0-5-8 branch**Revision 1.10.10.2 2002/10/08 04:16:57 ddiego*fixed a bug in the getClientBounds() that caused a stack overflow! DOH!*further additions to the TemplateNewClassDlg to sync the various file names*in the dialog to the lcass name**Revision 1.10.10.1 2002/10/01 20:34:59 ddiego*borders**Revision 1.10 2002/05/09 03:10:44 ddiego*merged over code from development branch devmain-0-5-1a into the main CVS trunk**Revision 1.9.4.1 2002/04/08 20:55:30 zzack*changed include style**Revision 1.9 2002/01/24 01:46:49 ddiego*added a cvs "log" comment to the top of all files in vcf/src and vcf/include*to facilitate change tracking**/
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?