/* =============================================================================== FILE: laswriter_las.hpp CONTENTS: Writes LiDAR points to the LAS format (Version 1.x). PROGRAMMERS: martin.isenburg@rapidlasso.com - http://rapidlasso.com COPYRIGHT: (c) 2007-2017, martin isenburg, rapidlasso - fast tools to catch reality This is free software; you can redistribute and/or modify it under the terms of the GNU Lesser General Licence as published by the Free Software Foundation. See the LICENSE.txt file for more information. This software is distributed WITHOUT ANY WARRANTY and without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. CHANGE HISTORY: 29 March 2017 -- read and write support "native LAS 1.4 extension" for LASzip 23 October 2016 -- support writing Extended Variable Length Records (ELVRs) 29 April 2016 -- added WARNINGs when rescale / reoffset overflows integers 13 October 2014 -- changed default IO buffer size with setvbuf() to 262144 5 November 2011 -- changed default IO buffer size with setvbuf() to 65536 8 May 2011 -- added an option for variable chunking via chunk() 23 April 2011 -- added additional open parameters to support chunking 21 January 2011 -- adapted from laswriter to create abstract reader class 3 December 2010 -- updated to (somewhat) support LAS format 1.3 7 September 2008 -- updated to support LAS format 1.2 21 February 2007 -- created after eating Sarah's veggies with peanutsauce =============================================================================== */ #ifndef LAS_WRITER_LAS_HPP #define LAS_WRITER_LAS_HPP #include "laswriter.hpp" #include #ifdef LZ_WIN32_VC6 #include #else #include #include using namespace std; #endif class ByteStreamOut; class LASwritePoint; class LASwriterLAS : public LASwriter { public: BOOL refile(FILE* file); void set_delete_stream(BOOL delete_stream=TRUE) { this->delete_stream = delete_stream; }; BOOL open(const LASheader* header, U32 compressor=LASZIP_COMPRESSOR_NONE, I32 requested_version=0, I32 chunk_size=50000); BOOL open(const char* file_name, const LASheader* header, U32 compressor=LASZIP_COMPRESSOR_NONE, I32 requested_version=0, I32 chunk_size=50000, I32 io_buffer_size=LAS_TOOLS_IO_OBUFFER_SIZE); BOOL open(FILE* file, const LASheader* header, U32 compressor=LASZIP_COMPRESSOR_NONE, I32 requested_version=0, I32 chunk_size=50000); BOOL open(ostream& ostream, const LASheader* header, U32 compressor=LASZIP_COMPRESSOR_NONE, I32 requested_version=0, I32 chunk_size=50000); BOOL open(ByteStreamOut* stream, const LASheader* header, U32 compressor=LASZIP_COMPRESSOR_NONE, I32 requested_version=0, I32 chunk_size=50000); BOOL write_point(const LASpoint* point); BOOL chunk(); BOOL update_header(const LASheader* header, BOOL use_inventory=FALSE, BOOL update_extra_bytes=FALSE); I64 close(BOOL update_npoints=TRUE); LASwriterLAS(); ~LASwriterLAS(); private: FILE* file; ByteStreamOut* stream; BOOL delete_stream; LASwritePoint* writer; I64 header_start_position; BOOL writing_las_1_4; BOOL writing_new_point_type; // for delayed write of EVLRs I64 start_of_first_extended_variable_length_record; U32 number_of_extended_variable_length_records; const LASevlr* evlrs; }; #endif