File: vtkXMLVVHandleWidgetReader.cxx

package info (click to toggle)
volview 3.4-3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 25,204 kB
  • sloc: cpp: 132,585; ansic: 11,612; tcl: 236; sh: 64; makefile: 25; xml: 8
file content (98 lines) | stat: -rw-r--r-- 2,884 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*=========================================================================

  Copyright (c) Kitware, Inc.
  All rights reserved.
  See Copyright.txt or http://www.kitware.com/VolViewCopyright.htm 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 notice for more information.

=========================================================================*/
#include "XML/vtkXMLVVHandleWidgetReader.h"

#include "vtkObjectFactory.h"
#include "vtkVVHandleWidget.h"
#include "vtkXMLDataElement.h"
#include "vtkHandleRepresentation.h"
#include "vtkImageActorPointHandleRepresentation3D.h"

#include "XML/vtkXMLHandleRepresentationReader.h"
#include "XML/vtkXMLVVHandleWidgetWriter.h"
#include <vtksys/ios/sstream>

vtkStandardNewMacro(vtkXMLVVHandleWidgetReader);
vtkCxxRevisionMacro(vtkXMLVVHandleWidgetReader, "$Revision: 1.4 $");

//----------------------------------------------------------------------------
const char* vtkXMLVVHandleWidgetReader::GetRootElementName()
{
  return "HandleWidget";
}

//----------------------------------------------------------------------------
int vtkXMLVVHandleWidgetReader::Parse(vtkXMLDataElement *elem)
{
  if (!this->Superclass::Parse(elem))
    {
    return 0;
    }

  vtkVVHandleWidget *obj = vtkVVHandleWidget::SafeDownCast(this->Object);
  if (!obj)
    {
    vtkWarningMacro(<< "The VVHandleWidget is not set!");
    return 0;
    }

  // Get nested elements
  
  int nb_nested_elems = elem->GetNumberOfNestedElements();
  for (int idx = 0; idx < nb_nested_elems; idx++)
    {
    vtkXMLDataElement *nested_elem = elem->GetNestedElement(idx);

    // ID

    if (!strcmp(nested_elem->GetName(), 
                vtkXMLVVHandleWidgetWriter::GetIDElementName()))
      {
      const char *cd = nested_elem->GetCharacterData();
      if (cd)
        {
        int ID;
        strstream is;
        is << cd << ends; // no istringstream in VTK
        is >> ID;
        is.rdbuf()->freeze(0);
        obj->SetID(ID);
        }
      }
    }
  
  // Representation

  vtkHandleRepresentation *rep = 
    vtkHandleRepresentation::SafeDownCast(obj->GetRepresentation());
  if (rep)
    {
    vtkXMLHandleRepresentationReader *xmlr = 
      vtkXMLHandleRepresentationReader::New();
    xmlr->SetObject(rep);
    vtkXMLDataElement *nested_elem = xmlr->ParseInNestedElement(
      elem, vtkXMLVVHandleWidgetWriter::GetRepresentationElementName());
    xmlr->Delete();
    vtkImageActorPointHandleRepresentation3D *repim3d = 
      vtkImageActorPointHandleRepresentation3D::SafeDownCast(rep);
    int ival;
    if (repim3d && 
        nested_elem->GetScalarAttribute("DisplayForAllSlices", ival))
      {
      repim3d->SetDisplayForAllSlices(ival);
      }
    obj->WidgetIsDefined();
    }

  return 1;
}