VTP转OFF

.vtp格式的文件转为.off格式:

1. CMakeLists.txt

cmake_minimum_required(VERSION 3.17)

PROJECT(VtpToOFF)

find_package(VTK REQUIRED)
include(${VTK_USE_FILE})

add_executable(VtpToOFF MACOSX_BUNDLE VtpToOFF vtkOFFWriter.cxx)

if(VTK_LIBRARIES)
  target_link_libraries(VtpToOFF ${VTK_LIBRARIES})
else()
  target_link_libraries(VtpToOFF vtkHybrid)
endif()

2. VTKOffWriter.h

#ifndef __vtkOFFWriter_h
#define __vtkOFFWriter_h

#include "vtkPolyDataWriter.h"

class vtkOFFWriter : public vtkPolyDataWriter
{
public:
  static vtkOFFWriter *New();
  vtkTypeMacro(vtkOFFWriter,vtkPolyDataWriter);
  void PrintSelf(ostream& os, vtkIndent indent);

protected:
  vtkOFFWriter();
  ~vtkOFFWriter();

  void WriteData();
  void WriteAsciiOFF(vtkPolyData *pd);
  void WriteBinaryOFF(vtkPolyData *pd);

private:
  vtkOFFWriter(const vtkOFFWriter&);  // Not implemented.
  void operator=(const vtkOFFWriter&);  // Not implemented.
};

#endif

3. VTKOffWriter.cxx

#include <vtkPolyData.h>
#include <vtkSmartPointer.h>
#include <vtksys/SystemTools.hxx>
#include <vtkXMLPolyDataReader.h>

#include "vtkOFFWriter.h"

#include <string>

int main(int argc, char *argv[])
{
  if (argc != 2)
    {
    std::cerr << "Usage: " << argv[0] << " Filename(.vtp)" << std::endl;
    return EXIT_FAILURE;
    }

  std::string inputFilename = argv[1];
  std::string outputFilename
    = vtksys::SystemTools::GetFilenameWithoutExtension(inputFilename) + ".off";

  vtkSmartPointer<vtkXMLPolyDataReader> reader =
    vtkSmartPointer<vtkXMLPolyDataReader>::New();
  reader->SetFileName(inputFilename.c_str());
  reader->Update();

  vtkSmartPointer<vtkOFFWriter> writer =
    vtkSmartPointer<vtkOFFWriter>::New();
  writer->SetFileName(outputFilename.c_str());
  writer->SetInputConnection(reader->GetOutputPort());
  writer->Write();

  return EXIT_SUCCESS;
}

4. VtpToOff.cxx

#include <vtkPolyData.h>
#include <vtkSmartPointer.h>
#include <vtksys/SystemTools.hxx>
#include <vtkXMLPolyDataReader.h>

#include "vtkOFFWriter.h"

#include <string>

int main(int argc, char *argv[])
{
  if (argc != 2)
    {
    std::cerr << "Usage: " << argv[0] << " Filename(.vtp)" << std::endl;
    return EXIT_FAILURE;
    }

  std::string inputFilename = argv[1];
  std::string outputFilename
    = vtksys::SystemTools::GetFilenameWithoutExtension(inputFilename) + ".off";

  vtkSmartPointer<vtkXMLPolyDataReader> reader =
    vtkSmartPointer<vtkXMLPolyDataReader>::New();
  reader->SetFileName(inputFilename.c_str());
  reader->Update();

  vtkSmartPointer<vtkOFFWriter> writer =
    vtkSmartPointer<vtkOFFWriter>::New();
  writer->SetFileName(outputFilename.c_str());
  writer->SetInputConnection(reader->GetOutputPort());
  writer->Write();

  return EXIT_SUCCESS;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值