1 /*# ---------------------------------------------------------------------
3 # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5 # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
6 # Previous Authors : Laurent Guigues, Jean-Pierre Roux
7 # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9 # This software is governed by the CeCILL-B license under French law and
10 # abiding by the rules of distribution of free software. You can use,
11 # modify and/ or redistribute the software under the terms of the CeCILL-B
12 # license as circulated by CEA, CNRS and INRIA at the following URL
13 # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
14 # or in the file LICENSE.txt.
16 # As a counterpart to the access to the source code and rights to copy,
17 # modify and redistribute granted by the license, users are provided only
18 # with a limited warranty and the software's author, the holder of the
19 # economic rights, and the successive licensors have only limited
22 # The fact that you are presently reading this means that you have had
23 # knowledge of the CeCILL-B license and that you accept its terms.
24 # ------------------------------------------------------------------------ */
26 #include "ManualPaintControler.h"
27 #include "vtkInteractorManualPaint.h"
28 #include "vtkImageActor.h"
30 //---------------------------------------------------------------------------
31 ManualPaintControler::ManualPaintControler() {
33 _wxvtk2Dbaseview = NULL;
36 //---------------------------------------------------------------------------
37 ManualPaintControler::~ManualPaintControler() {
40 //---------------------------------------------------------------------------
41 void ManualPaintControler::SetManualPaintModel(
42 ManualPaintModel* manualPaintModel) {
43 _manualPaintModel = manualPaintModel;
46 //---------------------------------------------------------------------------
47 void ManualPaintControler::SetManualPaintPanel(
48 ManualPaintPanel* manualPaintPanel) {
49 _manualPaintPanel = manualPaintPanel;
52 //---------------------------------------------------------------------------
53 void ManualPaintControler::SetWxVtk2DBaseView(
54 wxVtk2DBaseView *wxvtk2Dbaseview) {
55 _wxvtk2Dbaseview = wxvtk2Dbaseview;
58 //---------------------------------------------------------------------------
59 void ManualPaintControler::Config() {
60 if (_wxvtk2Dbaseview != NULL) {
61 vtkInteractorStyleBaseView *isbv =
62 (vtkInteractorStyleBaseView*) (_wxvtk2Dbaseview->GetInteractorStyleBaseView());
63 isbv->AddInteractorStyleMaracas(new vtkInteractorManualPaint(this));
67 //---------------------------------------------------------------------------
68 void ManualPaintControler::PaintImage(int px, int py, int pz) {
69 _manualPaintModel->SetDirection(_wxvtk2Dbaseview->GetDirection());
70 _manualPaintModel->PaintImage(px, py, pz);
72 // The refresh mechanisme is made in the vtkInteractorManualPaint
76 //---------------------------------------------------------------------------
77 void ManualPaintControler::SetImageUndo()
79 _manualPaintModel->SetUndoImage();