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
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkLookupTableWithEnabling.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.
=========================================================================*/
/**
* @class vtkLookupTableWithEnabling
* @brief A lookup table that allows for an
* optional array to be provided that specifies which scalars to "enable" and
* which to "disable".
*
*
* vtkLookupTableWithEnabling "disables" or "grays out" output colors
* based on whether the given value in EnabledArray is "0" or not.
*
*
* @warning
* You must set the EnabledArray before MapScalars() is called.
* Indices of EnabledArray must map directly to those of the array passed
* to MapScalars().
*
*/
#ifndef vtkLookupTableWithEnabling_h
#define vtkLookupTableWithEnabling_h
#include "vtkLookupTable.h"
#include "vtkRenderingCoreModule.h" // For export macro
VTK_ABI_NAMESPACE_BEGIN
class vtkDataArray;
class VTKRENDERINGCORE_EXPORT vtkLookupTableWithEnabling : public vtkLookupTable
{
public:
static vtkLookupTableWithEnabling* New();
vtkTypeMacro(vtkLookupTableWithEnabling, vtkLookupTable);
void PrintSelf(ostream& os, vtkIndent indent) override;
///@{
/**
* This must be set before MapScalars() is called.
* Indices of this array must map directly to those in the scalars array
* passed to MapScalars().
* Values of 0 in the array indicate the color should be desaturatated.
*/
vtkGetObjectMacro(EnabledArray, vtkDataArray);
virtual void SetEnabledArray(vtkDataArray* enabledArray);
///@}
/**
* Map a set of scalars through the lookup table.
*/
void MapScalarsThroughTable2(void* input, unsigned char* output, int inputDataType,
int numberOfValues, int inputIncrement, int outputFormat) override;
/**
* A convenience method for taking a color and desaturating it.
*/
virtual void DisableColor(unsigned char r, unsigned char g, unsigned char b, unsigned char* rd,
unsigned char* gd, unsigned char* bd);
protected:
vtkLookupTableWithEnabling(int sze = 256, int ext = 256);
~vtkLookupTableWithEnabling() override;
vtkDataArray* EnabledArray;
private:
vtkLookupTableWithEnabling(const vtkLookupTableWithEnabling&) = delete;
void operator=(const vtkLookupTableWithEnabling&) = delete;
};
VTK_ABI_NAMESPACE_END
#endif
|