Shinya Kitaoka 810553
#pragma once
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#ifndef MESHBUILDER_H
Toshihiro Shimizu 890ddd
#define MESHBUILDER_H
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
// TnzCore includes
Toshihiro Shimizu 890ddd
#include "trasterimage.h"
Toshihiro Shimizu 890ddd
#include "tmeshimage.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#undef DVAPI
Toshihiro Shimizu 890ddd
#undef DVVAR
Toshihiro Shimizu 890ddd
#ifdef TNZEXT_EXPORTS
Toshihiro Shimizu 890ddd
#define DVAPI DV_EXPORT_API
Toshihiro Shimizu 890ddd
#define DVVAR DV_EXPORT_VAR
Toshihiro Shimizu 890ddd
#else
Toshihiro Shimizu 890ddd
#define DVAPI DV_IMPORT_API
Toshihiro Shimizu 890ddd
#define DVVAR DV_IMPORT_VAR
Toshihiro Shimizu 890ddd
#endif
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//********************************************************************************************
Toshihiro Shimizu 890ddd
//    Mesh Image Builder  functions
Toshihiro Shimizu 890ddd
//********************************************************************************************
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
struct MeshBuilderOptions {
Shinya Kitaoka 120a6e
  int m_margin;               //!< Mesh margin to the original shape (in pixels)
Shinya Kitaoka 120a6e
  double m_targetEdgeLength;  //!< The target mesh edge length
Shinya Kitaoka 120a6e
  int m_targetMaxVerticesCount;  //!< The desired maximum vertices count
Shinya Kitaoka 120a6e
                                 //!< (the returned mesh could still be larger)
Shinya Kitaoka 120a6e
  TPixel64 m_transparentColor;   //!< Color to be used as transparent for
Shinya Kitaoka 120a6e
                                 //!boundaries recognition
Shinya Kitaoka 120a6e
                                 //!< (for fullcolor images only).
Shinya Kitaoka 120a6e
  //!< \note Transparent colors will be recognized as transparent
Shinya Kitaoka 120a6e
  //!< anyway
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//=======================================================================================
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//! Builds a mesh image from the specified raster.
Toshihiro Shimizu 890ddd
/*!
Shinya Kitaoka 120a6e
  This function extracts a TMeshImage type from the passed raster, using
Shinya Kitaoka 120a6e
  transparent
Toshihiro Shimizu 890ddd
  pixels to identify the mesh boundary.
Toshihiro Shimizu 890ddd
  \n\n
Shinya Kitaoka 120a6e
  The returned mesh image has coordinates in the original raster reference (ie
Shinya Kitaoka 120a6e
  origin at
Toshihiro Shimizu 890ddd
  the lower-left image corner, pixel metric)
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  \warning The resulting mesh image has  no dpi <\B>. Users \b must set it
Shinya Kitaoka 120a6e
  manually after
Toshihiro Shimizu 890ddd
           this function has been invoked.
Toshihiro Shimizu 890ddd
*/
Shinya Kitaoka 120a6e
DVAPI TMeshImageP buildMesh(const TRasterP &ras,
Shinya Kitaoka 120a6e
                            const MeshBuilderOptions &options);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
#endif  // MESHBUILDER_H