X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fwx%2Fsrc%2FbbwxSlider.h;h=d75d02dc63582a96139e95dfae9f38f0cfbc4a3c;hb=cfad95b6e08e6e53846ffcda7fbc5932065f2c47;hp=9c93a7ff5eb997e442f8fbe73d16ae78bbbecb4c;hpb=66a3ecd89537e1445311a4298f53b8ba6cf2b0eb;p=bbtk.git diff --git a/packages/wx/src/bbwxSlider.h b/packages/wx/src/bbwxSlider.h index 9c93a7f..d75d02d 100644 --- a/packages/wx/src/bbwxSlider.h +++ b/packages/wx/src/bbwxSlider.h @@ -1,20 +1,38 @@ +/* + # --------------------------------------------------------------------- + # + # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image + # pour la SantÈ) + # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton + # Previous Authors : Laurent Guigues, Jean-Pierre Roux + # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil + # + # This software is governed by the CeCILL-B license under French law and + # abiding by the rules of distribution of free software. You can use, + # modify and/ or redistribute the software under the terms of the CeCILL-B + # license as circulated by CEA, CNRS and INRIA at the following URL + # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html + # or in the file LICENSE.txt. + # + # As a counterpart to the access to the source code and rights to copy, + # modify and redistribute granted by the license, users are provided only + # with a limited warranty and the software's author, the holder of the + # economic rights, and the successive licensors have only limited + # liability. + # + # The fact that you are presently reading this means that you have had + # knowledge of the CeCILL-B license and that you accept its terms. + # ------------------------------------------------------------------------ */ + + /*========================================================================= - Program: bbtk Module: $RCSfile: bbwxSlider.h,v $ Language: C++ - Date: $Date: 2008/01/28 08:56:02 $ - Version: $Revision: 1.3 $ - - Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de - l'Image). All rights reserved. See Doc/License.txt or - http://www.creatis.insa-lyon.fr/Public/bbtk/License.html for details. - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notices for more information. - -=========================================================================*//** + Date: $Date: 2012/11/16 08:52:14 $ + Version: $Revision: 1.19 $ +=========================================================================*/ + /** * \file * \brief Short description in one line @@ -31,10 +49,8 @@ * \brief */ - #ifdef _USE_WXWIDGETS_ - // Prevents multiple inclusions : use symbols of the form // __FILENAME_INCLUDED__ // where FILENAME must be replaced by the actual file name @@ -44,6 +60,7 @@ // Include wxBlackBox definition #include "bbtkWxBlackBox.h" +#include "bbwx_EXPORT.h" // Namespace of the package "wx" is "bbwx" @@ -51,94 +68,28 @@ // bbPACKAGENAME namespace bbwx { - - - - - - - //-------------------------------------------------------------------------- - // Forward declaration of the box - class Slider; - //-------------------------------------------------------------------------- - - - - - //-------------------------------------------------------------------------- - // The widget created by the box - class SliderWidget : public wxPanel - { - public: - /// Ctor with the two first params the parent window and the creator box - /// which must be passed to the WxBlackBoxWidget constructor. - /// The other params initialize the widget - SliderWidget(Slider* box, wxWindow *parent, - int orientation, - bool changeresolution, - bool label, - wxString title, - int vmin, - int vmax, - int value, - int track); - /// Dtor - ~SliderWidget(); - /// Events callbacks - /// Called when the slider is moved - void OnSliderTrack(wxScrollEvent& event); - /// Called when the slider is released - void OnSliderRelease(wxScrollEvent& event); - /// Called when the little slider which controls the resolution - /// of the main slider is moved (if activated) - void OnResolutionOfSlider(wxScrollEvent& event); - - // Accessors - int GetValue() { return mwxSlider->GetValue(); } - void SetRange(int min, int max); - // Update the texts which display the min/max/current values of the slider - void RefreshLabels(); - - private: - Slider* mBox; - wxSlider *mwxSlider; - wxSlider *mResolutionOfSlider; - int min; - int max; - int reactiveOnTrack; - wxStaticText *label_vertical; - wxStaticText *label_min; - wxStaticText *label_max; - }; - //------------------------------------------------------------------------ - //------------------------------------------------------------------------ - //------------------------------------------------------------------------ - - - //------------------------------------------------------------------------ // The black box - class /*BBTK_EXPORT*/ Slider : public bbtk::WxBlackBox - { - - BBTK_USER_BLACK_BOX_INTERFACE(Slider,bbtk::WxBlackBox); + class bbwx_EXPORT Slider : public bbtk::WxBlackBox + { + BBTK_BLACK_BOX_INTERFACE(Slider,bbtk::WxBlackBox); BBTK_DECLARE_INPUT(In,int); BBTK_DECLARE_INPUT(Min,int); BBTK_DECLARE_INPUT(Max,int); BBTK_DECLARE_INPUT(Label,bool); BBTK_DECLARE_INPUT(Title,std::string); - BBTK_DECLARE_INPUT(Orientation,int); + BBTK_DECLARE_INPUT(Orientation,std::string); BBTK_DECLARE_INPUT(ChangeResolution,bool); - BBTK_DECLARE_INPUT(ReactiveOnTrack,int); + BBTK_DECLARE_INPUT(ReactiveOnTrack,bool); BBTK_DECLARE_OUTPUT(Out,int); BBTK_PROCESS(Process); BBTK_CREATE_WIDGET(CreateWidget); void Process(); - void CreateWidget(); + void CreateWidget(wxWindow*); protected: - virtual void bbUserConstructor(); + }; //================================================================= @@ -147,24 +98,20 @@ namespace bbwx BBTK_BEGIN_DESCRIBE_BLACK_BOX(Slider,bbtk::WxBlackBox); BBTK_NAME("Slider"); BBTK_AUTHOR("eduardo.davila@creatis.insa-lyon.fr"); + // Already inserted for any WxBlackBox BBTK_CATEGORY("widget"); BBTK_DESCRIPTION("Slider widget (wxSlider)"); - BBTK_INPUT(Slider,In,"Initial position of the slider (default 0)",int); - BBTK_INPUT(Slider,Min,"Minimum value of the slider (default 0)",int); - BBTK_INPUT(Slider,Max,"Maximum value of the slider (default 500)",int); - BBTK_INPUT(Slider,Label,"Show slider labels ? (default FALSE) ",bool); - BBTK_INPUT(Slider,Title,"Title shown above the slider (default '') ", - std::string); - BBTK_INPUT(Slider,Orientation, - "Orientation : 0=Horizontal / 1=Vertical (default 0)",int); - BBTK_INPUT(Slider,ChangeResolution, - "Can the user change the resolution of the slider ? (default FALSE) ",bool); - BBTK_INPUT(Slider,ReactiveOnTrack, - "Slider sends info when track moves (default 0 = no)",int); - BBTK_OUTPUT(Slider,Out,"Current position of the slider",int); + BBTK_INPUT(Slider,In, "Initial position of the slider (default 0)", int, ""); + BBTK_INPUT(Slider,Min, "Minimum value of the slider (default 0)", int, ""); + BBTK_INPUT(Slider,Max, "Maximum value of the slider (default 500)", int, ""); + BBTK_INPUT(Slider,Label, "Show slider labels ? (default FALSE) ", bool, ""); + BBTK_INPUT(Slider,Title, "Title shown above the slider (default '') ", std::string, ""); + BBTK_INPUT(Slider,Orientation, "Orientation : (default H) 0=H=HORIZONTAL, 1=V=VERTICAL ", std::string, ""); + BBTK_INPUT(Slider,ChangeResolution, "Can the user change the resolution of the slider ? (default FALSE) ", bool, ""); + BBTK_INPUT(Slider,ReactiveOnTrack, "Slider sends info when track moves (default : FALSE)", bool, ""); + + BBTK_OUTPUT(Slider,Out,"Current position of the slider",int,""); BBTK_END_DESCRIBE_BLACK_BOX(Slider); //================================================================= - - } //namespace bbwx