2015-04-28 11:54:17 +00:00
|
|
|
/* ========================================================================= *
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
|
|
|
|
* OpenMesh *
|
2015-04-28 11:33:32 +00:00
|
|
|
* Copyright (c) 2001-2015, RWTH-Aachen University *
|
2015-04-28 13:07:46 +00:00
|
|
|
* Department of Computer Graphics and Multimedia *
|
2015-04-28 11:33:32 +00:00
|
|
|
* All rights reserved. *
|
|
|
|
|
* www.openmesh.org *
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
2012-10-08 13:25:36 +00:00
|
|
|
*---------------------------------------------------------------------------*
|
2015-04-28 11:33:32 +00:00
|
|
|
* This file is part of OpenMesh. *
|
|
|
|
|
*---------------------------------------------------------------------------*
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
2015-04-28 11:33:32 +00:00
|
|
|
* Redistribution and use in source and binary forms, with or without *
|
|
|
|
|
* modification, are permitted provided that the following conditions *
|
|
|
|
|
* are met: *
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
2015-04-28 11:33:32 +00:00
|
|
|
* 1. Redistributions of source code must retain the above copyright notice, *
|
|
|
|
|
* this list of conditions and the following disclaimer. *
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
2015-04-28 11:33:32 +00:00
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright *
|
|
|
|
|
* notice, this list of conditions and the following disclaimer in the *
|
|
|
|
|
* documentation and/or other materials provided with the distribution. *
|
2009-02-06 13:37:46 +00:00
|
|
|
* *
|
2015-04-28 11:33:32 +00:00
|
|
|
* 3. Neither the name of the copyright holder nor the names of its *
|
|
|
|
|
* contributors may be used to endorse or promote products derived from *
|
|
|
|
|
* this software without specific prior written permission. *
|
2009-06-04 08:46:29 +00:00
|
|
|
* *
|
2015-04-28 11:33:32 +00:00
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
|
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
|
|
|
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
|
|
|
|
|
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
|
|
|
|
|
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
|
|
|
|
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
|
|
|
|
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
|
|
|
|
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
|
|
|
|
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
|
|
|
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
|
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
|
2015-04-28 11:54:17 +00:00
|
|
|
* *
|
|
|
|
|
* ========================================================================= */
|
2009-06-04 08:46:29 +00:00
|
|
|
|
2019-01-15 11:21:12 +01:00
|
|
|
|
2009-02-06 13:37:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
|
//
|
|
|
|
|
// Implements a reader module for OFF files
|
|
|
|
|
//
|
|
|
|
|
//=============================================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __OMREADER_HH__
|
|
|
|
|
#define __OMREADER_HH__
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//=== INCLUDES ================================================================
|
|
|
|
|
|
|
|
|
|
// OpenMesh
|
|
|
|
|
#include <OpenMesh/Core/System/config.h>
|
|
|
|
|
#include <OpenMesh/Core/Utils/SingletonT.hh>
|
|
|
|
|
#include <OpenMesh/Core/IO/OMFormat.hh>
|
|
|
|
|
#include <OpenMesh/Core/IO/IOManager.hh>
|
|
|
|
|
#include <OpenMesh/Core/IO/importer/BaseImporter.hh>
|
|
|
|
|
#include <OpenMesh/Core/IO/reader/BaseReader.hh>
|
|
|
|
|
|
|
|
|
|
// STD C++
|
2015-06-09 08:58:41 +00:00
|
|
|
#include <iosfwd>
|
2009-02-06 13:37:46 +00:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//== NAMESPACES ===============================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace OpenMesh {
|
|
|
|
|
namespace IO {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//== IMPLEMENTATION ===========================================================
|
|
|
|
|
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
/**
|
|
|
|
|
Implementation of the OM format reader. This class is singleton'ed by
|
2009-02-06 13:37:46 +00:00
|
|
|
SingletonT to OMReader.
|
|
|
|
|
*/
|
2012-09-23 14:49:46 +00:00
|
|
|
class OPENMESHDLLEXPORT _OMReader_ : public BaseReader
|
2009-02-06 13:37:46 +00:00
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
_OMReader_();
|
|
|
|
|
virtual ~_OMReader_() { }
|
|
|
|
|
|
2019-05-28 11:50:49 +02:00
|
|
|
std::string get_description() const override { return "OpenMesh File Format"; }
|
|
|
|
|
std::string get_extensions() const override { return "om"; }
|
|
|
|
|
std::string get_magic() const override { return "OM"; }
|
2012-10-08 13:25:36 +00:00
|
|
|
|
|
|
|
|
bool read(const std::string& _filename,
|
|
|
|
|
BaseImporter& _bi,
|
2019-05-28 11:50:49 +02:00
|
|
|
Options& _opt ) override;
|
2009-02-06 13:37:46 +00:00
|
|
|
|
2009-11-17 13:54:16 +00:00
|
|
|
//! Stream Reader for std::istream input in binary format
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read(std::istream& _is,
|
|
|
|
|
BaseImporter& _bi,
|
2019-05-28 11:50:49 +02:00
|
|
|
Options& _opt ) override;
|
2012-10-08 13:25:36 +00:00
|
|
|
|
2019-05-28 11:50:49 +02:00
|
|
|
virtual bool can_u_read(const std::string& _filename) const override;
|
2009-02-06 13:37:46 +00:00
|
|
|
virtual bool can_u_read(std::istream& _is) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
|
2009-02-06 13:37:46 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
|
|
bool supports( const OMFormat::uint8 version ) const;
|
|
|
|
|
|
|
|
|
|
bool read_ascii(std::istream& _is, BaseImporter& _bi, Options& _opt) const;
|
|
|
|
|
bool read_binary(std::istream& _is, BaseImporter& _bi, Options& _opt) const;
|
|
|
|
|
|
|
|
|
|
typedef OMFormat::Header Header;
|
|
|
|
|
typedef OMFormat::Chunk::Header ChunkHeader;
|
|
|
|
|
typedef OMFormat::Chunk::PropertyName PropertyName;
|
|
|
|
|
|
|
|
|
|
// initialized/updated by read_binary*/read_ascii*
|
|
|
|
|
mutable size_t bytes_;
|
2012-10-08 13:25:36 +00:00
|
|
|
mutable Options fileOptions_;
|
2009-02-06 13:37:46 +00:00
|
|
|
mutable Header header_;
|
|
|
|
|
mutable ChunkHeader chunk_header_;
|
|
|
|
|
mutable PropertyName property_name_;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read_binary_vertex_chunk( std::istream &_is,
|
|
|
|
|
BaseImporter &_bi,
|
2009-02-06 13:37:46 +00:00
|
|
|
Options &_opt,
|
|
|
|
|
bool _swap) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read_binary_face_chunk( std::istream &_is,
|
|
|
|
|
BaseImporter &_bi,
|
2009-02-06 13:37:46 +00:00
|
|
|
Options &_opt,
|
|
|
|
|
bool _swap) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read_binary_edge_chunk( std::istream &_is,
|
|
|
|
|
BaseImporter &_bi,
|
2009-02-06 13:37:46 +00:00
|
|
|
Options &_opt,
|
|
|
|
|
bool _swap) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read_binary_halfedge_chunk( std::istream &_is,
|
|
|
|
|
BaseImporter &_bi,
|
2009-02-06 13:37:46 +00:00
|
|
|
Options &_opt,
|
|
|
|
|
bool _swap) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
bool read_binary_mesh_chunk( std::istream &_is,
|
|
|
|
|
BaseImporter &_bi,
|
2009-02-06 13:37:46 +00:00
|
|
|
Options &_opt,
|
|
|
|
|
bool _swap) const;
|
|
|
|
|
|
2012-10-08 13:25:36 +00:00
|
|
|
size_t restore_binary_custom_data( std::istream& _is,
|
2009-02-06 13:37:46 +00:00
|
|
|
BaseProperty* _bp,
|
2012-10-08 13:25:36 +00:00
|
|
|
size_t _n_elem,
|
2009-02-06 13:37:46 +00:00
|
|
|
bool _swap) const;
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//== TYPE DEFINITION ==========================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// Declare the single entity of the OM reader.
|
|
|
|
|
extern _OMReader_ __OMReaderInstance;
|
2012-09-24 10:10:22 +00:00
|
|
|
OPENMESHDLLEXPORT _OMReader_& OMReader();
|
2009-02-06 13:37:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
|
} // namespace IO
|
|
|
|
|
} // namespace OpenMesh
|
|
|
|
|
//=============================================================================
|
|
|
|
|
#endif
|
|
|
|
|
//=============================================================================
|