PfmVizzer
- 
class PfmVizzer
- This class aids in the visualization and manipulation of - PfmFileobjects.- Inheritance diagram - 
enum ColumnType
- 
enumerator CT_texcoord2 = 0
 - 
enumerator CT_texcoord3 = 1
 - 
enumerator CT_vertex1 = 2
 - 
enumerator CT_vertex2 = 3
 - 
enumerator CT_vertex3 = 4
 - 
enumerator CT_normal3 = 5
 - 
enumerator CT_blend1 = 6
 - 
enumerator CT_aux_vertex1 = 7
 - 
enumerator CT_aux_vertex2 = 8
 - 
enumerator CT_aux_vertex3 = 9
 
- 
enumerator CT_texcoord2 = 0
 - 
PfmVizzer(PfmVizzer const&) = default
- The - PfmVizzerconstructor receives a reference to a- PfmFilewhich it will operate on. It does not keep ownership of this reference; it is your responsibility to ensure the- PfmFiledoes not destruct during the lifetime of the- PfmVizzer.
 - 
void add_vis_column(PfmVizzer::ColumnType source, ColumnType target, InternalName *name, TransformState const *transform = nullptr, Lens const *lens = nullptr, PfmFile const *undist_lut = nullptr)
- Adds a new vis column specification to the list of vertex data columns that will be generated at the next call to - generate_vis_points()or- generate_vis_mesh(). This advanced interface supercedes the higher-level- set_vis_inverse(),- set_flat_texcoord_name(), and- set_vis_2d().- If you use this advanced interface, you must specify explicitly the complete list of data columns to be created in the resulting - GeomVertexData, by calling add_vis_column() each time. For each column, you specify the source of the column in the PFMFile, the target column and name in the- GeomVertexData, and an optional transform matrix and/or lens to transform and project the point before generating it.- The private implementation of the public add_vis_column(), this adds the column to the indicated specific vector. 
 - 
double calc_max_u_displacement(void) const
- Computes the maximum amount of shift, in pixels either left or right, of any pixel in the distortion map. This can be passed to - make_displacement(); see that function for more information.
 - 
double calc_max_v_displacement(void) const
- Computes the maximum amount of shift, in pixels either up or down, of any pixel in the distortion map. This can be passed to - make_displacement(); see that function for more information.
 - 
void clear_flat_texcoord_name(void)
- Resets the flat_texcoord_name to empty, so that additional texture coordinates are not created. - This may be used in lieu of the lower-level - add_vis_column().
 - 
void clear_vis_blend(void)
- Removes the blending map set by a prior call to - set_vis_blend().
 - 
void clear_vis_columns(void)
- Removes all of the previously-added vis columns in preparation for building a new list. See - add_vis_column().
 - 
void extrude(Lens const *lens)
- Converts each (u, v, depth) point of the Pfm file to an (x, y, z) point, by reversing - project(). If the original file is only a 1-d file, assumes that it is a depth map with implicit (u, v) coordinates.- This method is only valid for a linear lens (e.g. a - PerspectiveLensor- OrthographicLens). Non-linear lenses don’t necessarily compute a sensible depth coordinate.
 - 
NodePath generate_vis_mesh(PfmVizzer::MeshFace face = MF_front) const
- Creates a triangle mesh with the points of the pfm as 3-d coordinates in space, and texture coordinates ranging from 0 .. 1 based on the position within the pfm grid. 
 - 
NodePath generate_vis_points(void) const
- Creates a point cloud with the points of the pfm as 3-d coordinates in space, and texture coordinates ranging from 0 .. 1 based on the position within the pfm grid. 
 - 
PfmFile const *get_aux_pfm(void) const
- Returns the reference to the auxiliary - PfmFilequeried by this- PfmVizzer. This contains the values that will be reflected in CT_aux_vertex3 etc. See- set_aux_pfm().
 - 
InternalName *get_flat_texcoord_name(void) const
- Returns the flat_texcoord_name. See - set_flat_texcoord_name().
 - 
bool get_keep_beyond_lens(void) const
- Returns the keep_beyond_lens flag. See - set_keep_beyond_lens().
 - 
PfmFile const &get_pfm(void) const
- Returns the reference to the - PfmFilemanipulated by this- PfmVizzer.
 - 
bool get_vis_2d(void) const
- Returns the vis_2d flag. See - set_vis_2d().
 - 
PNMImage const *get_vis_blend(void) const
- Returns the blending map set by the most recent call to - set_vis_blend(), or NULL if there is no blending map in effect.
 - 
bool get_vis_inverse(void) const
- Returns the vis_inverse flag. See - set_vis_inverse().
 - 
void make_displacement(PfmFile &result, double max_u, double max_v, bool for_32bit) const
- Assuming the underlying - PfmFileis a 2-d distortion mesh, with the U and V in the first two components and the third component unused, this computes an AfterEffects-style displacement map that represents the same distortion. The indicated- PNMImagewill be filled in with a displacement map image, with horizontal shift in the red channel and vertical shift in the green channel, where a fully bright (or fully black) pixel indicates a shift of max_u or max_v pixels.- Use - calc_max_u_displacement()and- calc_max_v_displacement()to compute suitable values for max_u and max_v.- This generates an integer 16-bit displacement image. It is a good idea, though not necessarily essential, to check “Preserve RGB” in the interpret footage section for each displacement image. Set for_32bit true if this is meant to be used in a 32-bit project file, and false if it is meant to be used in a 16-bit project file. - Assuming the underlying - PfmFileis a 2-d distortion mesh, with the U and V in the first two components and the third component unused, this computes an AfterEffects-style displacement map that represents the same distortion. The indicated- PNMImagewill be filled in with a displacement map image, with horizontal shift in the red channel and vertical shift in the green channel, where a fully bright (or fully black) pixel indicates a shift of max_u or max_v pixels.- Use - calc_max_u_displacement()and- calc_max_v_displacement()to compute suitable values for max_u and max_v.- This generates a 32-bit floating-point displacement image. It is essential to check “Preserve RGB” in the interpret footage section for each displacement image. Set for_32bit true if this is meant to be used in a 32-bit project file, and false if it is meant to be used in a 16-bit project file. 
 - 
void project(Lens const *lens, PfmFile const *undist_lut = nullptr)
- Adjusts each (x, y, z) point of the Pfm file by projecting it through the indicated lens, converting each point to a (u, v, w) texture coordinate. The resulting file can be generated to a mesh (with set_vis_inverse(true) and - generate_vis_mesh()) that will apply the lens distortion to an arbitrary texture image.
 - 
void set_aux_pfm(PfmFile const *pfm)
- Assigns an auxiliary - PfmFileto this- PfmVizzer. This file will be queried by column types CT_aux_vertex1/2/3, but has no other meaning to the vizzer. This size of this- PfmFileshould exactly match the base- PfmFile. No reference count is held and no copy is made; the caller is responsible for ensuring that the auxiliary- PfmFilewill persist throughout the lifetime of the- PfmVizzerit is assigned to.
 - 
void set_flat_texcoord_name(InternalName *flat_texcoord_name)
- If the flat_texcoord_name is specified, it is the name of an additional vertex column that will be created for the “flat” texture coordinates, i.e. the original 0..1 values that correspond to the 2-D index position of each point in the original pfm file. - These are the same values that will be assigned to the default texture coordinates if the vis_inverse flag is not true. - This may be used in lieu of the lower-level - add_vis_column().
 - 
void set_keep_beyond_lens(bool keep_beyond_lens)
- Sets the keep_beyond_lens flag. When this flag is true, points that fall outside of the normal lens range in - project()or in- add_vis_column()will be retained anyway; when it is false, these points will be discarded.
 - 
void set_vis_2d(bool vis_2d)
- Sets the vis_2d flag. When this flag is true, only the first two (x, y) value of each depth point is considered meaningful; the z component is ignored. This is only relevant for generating visualizations. - This may be used in lieu of the lower-level - add_vis_column().
 - 
void set_vis_blend(PNMImage const *vis_blend)
- Specifies a blending map–a grayscale image–that will be applied to the vertex color during - generate_vis_mesh()and- generate_vis_points(). The image size must exactly match the mesh size of the- PfmVizzer.- Ownership of the pointer is not kept by the - PfmVizzer; it is your responsibility to ensure it does not destruct during the lifetime of the- PfmVizzer(or at least not before your subsequent call to- generate_vis_mesh()).
 - 
void set_vis_inverse(bool vis_inverse)
- Sets the vis_inverse flag. When this flag is true, vis meshes and point clouds are generated with the 3-d depth value in the texture coordinates, and the 2-d index value in the vertex position. When it is false, meshes are generated normally, with the 3-d depth value in the vertex position and the 2-d index value in the texture coordinates. - This may be used in lieu of the lower-level - add_vis_column().
 
- 
enum ColumnType
