/usr/include/vtk-5.8/vtkQtAbstractModelAdapter.h is in libvtk5-dev 5.8.0-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkQtAbstractModelAdapter.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.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.
=========================================================================*/
/*-------------------------------------------------------------------------
Copyright 2008 Sandia Corporation.
Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
the U.S. Government retains certain rights in this software.
-------------------------------------------------------------------------*/
// .NAME vtkQtAbstractModelAdapter - Superclass for Qt model adapters.
//
// .SECTION Description
// vtkQtAbstractModelAdapter is the superclass for classes that adapt
// VTK objects to QAbstractItemModel. This class contains API for converting
// between QModelIndex and VTK ids, as well as some additional specialized
// functionality such as setting a column of data to use as the Qt header
// information.
//
// .SECTION See also
// vtkQtTableModelAdapter vtkQtTreeModelAdapter
#ifndef __vtkQtAbstractModelAdapter_h
#define __vtkQtAbstractModelAdapter_h
#include "QVTKWin32Header.h"
#include <QAbstractItemModel>
#include <QItemSelection>
class vtkDataObject;
class vtkSelection;
class QItemSelection;
class QVTK_EXPORT vtkQtAbstractModelAdapter : public QAbstractItemModel
{
Q_OBJECT
public:
// The view types.
enum {
FULL_VIEW,
DATA_VIEW
};
vtkQtAbstractModelAdapter(QObject* p) :
QAbstractItemModel(p),
ViewType(FULL_VIEW),
KeyColumn(-1),
ColorColumn(-1),
DataStartColumn(-1),
DataEndColumn(-1)
{ }
// Description:
// Set/Get the VTK data object as input to this adapter
virtual void SetVTKDataObject(vtkDataObject *data) = 0;
virtual vtkDataObject* GetVTKDataObject() const = 0;
// Description:
// Selection conversion from VTK land to Qt land
virtual vtkSelection* QModelIndexListToVTKIndexSelection(
const QModelIndexList qmil) const = 0;
virtual QItemSelection VTKIndexSelectionToQItemSelection(
vtkSelection *vtksel) const = 0;
// Description:
// Set/Get the view type.
// FULL_VIEW gives access to all the data.
// DATA_VIEW gives access only to the data columns specified with SetDataColumnRange()
// The default is FULL_VIEW.
virtual void SetViewType(int type) { this->ViewType = type; }
virtual int GetViewType() { return this->ViewType; }
// Description:
// Set/Get the key column.
// The key column is used as the row headers in a table view,
// and as the first column in a tree view.
// Set to -1 for no key column.
// The default is no key column.
virtual void SetKeyColumn(int col) { this->KeyColumn = col; }
virtual int GetKeyColumn() { return this->KeyColumn; }
virtual void SetKeyColumnName(const char* name) = 0;
// Description:
// Set/Get the column storing the rgba color values for each row.
// The color column is used as the row headers in a table view,
// and as the first column in a tree view.
// Set to -1 for no key column.
// The default is no key column.
virtual void SetColorColumn(int col) { this->ColorColumn = col; }
virtual int GetColorColumn() { return this->ColorColumn; }
virtual void SetColorColumnName(const char* name) = 0;
// Description:
// Set the range of columns that specify the main data matrix.
// The data column range should not include the key column.
// The default is no data columns.
virtual void SetDataColumnRange(int c1, int c2)
{ this->DataStartColumn = c1; this->DataEndColumn = c2; }
// We make the reset() method public because it isn't always possible for
// an adapter to know when its input has changed, so it must be callable
// by an outside entity.
void reset() { QAbstractItemModel::reset(); }
signals:
void modelChanged();
protected:
// Description:
// Map a column index in the QAbstractItemModel to a vtkTable column.
// If the argument is out of range or cannot be mapped then
// this method may return -1.
virtual int ModelColumnToFieldDataColumn(int col) const;
int ViewType;
int KeyColumn;
int ColorColumn;
int DataStartColumn;
int DataEndColumn;
};
#endif
|