[Liblas-commits] laszip: enable laszip building
liblas-commits at liblas.org
liblas-commits at liblas.org
Tue Jan 19 13:14:50 EST 2010
changeset df37a075671b in /Volumes/Data/www/liblas.org/laszip
details: http://hg.liblas.orglaszip?cmd=changeset;node=df37a075671b
summary: enable laszip building
diffstat:
.hgignore | 1 +
Makefile.am | 2 +-
configure.ac | 1 +
tools/Makefile.am | 7 +
tools/laszip.cpp | 446 ++++++++++++++++++++++++++++++++++++++++++++++++++
tools/src/Makefile.am | 6 -
tools/src/laszip.cpp | 446 --------------------------------------------------
7 files changed, 456 insertions(+), 453 deletions(-)
diffs (truncated from 950 to 300 lines):
diff -r cfa49ef4b213 -r df37a075671b .hgignore
--- a/.hgignore Tue Jan 19 11:50:33 2010 -0600
+++ b/.hgignore Tue Jan 19 12:10:21 2010 -0600
@@ -64,3 +64,4 @@
Release
.DS_Store
laszip-config
+tools/laszip
diff -r cfa49ef4b213 -r df37a075671b Makefile.am
--- a/Makefile.am Tue Jan 19 11:50:33 2010 -0600
+++ b/Makefile.am Tue Jan 19 12:10:21 2010 -0600
@@ -1,4 +1,4 @@
-SUBDIRS = src . include
+SUBDIRS = src . include tools
lib_LTLIBRARIES = liblaszip.la
diff -r cfa49ef4b213 -r df37a075671b configure.ac
--- a/configure.ac Tue Jan 19 11:50:33 2010 -0600
+++ b/configure.ac Tue Jan 19 12:10:21 2010 -0600
@@ -118,6 +118,7 @@
Makefile
include/Makefile
src/Makefile
+ tools/Makefile
laszip-config
])
diff -r cfa49ef4b213 -r df37a075671b tools/Makefile.am
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/Makefile.am Tue Jan 19 12:10:21 2010 -0600
@@ -0,0 +1,7 @@
+
+AM_CPPFLAGS = -I../include
+LDADD = ../liblaszip.la
+
+laszip_SOURCES = laszip.cpp
+
+bin_PROGRAMS = laszip
\ No newline at end of file
diff -r cfa49ef4b213 -r df37a075671b tools/laszip.cpp
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/laszip.cpp Tue Jan 19 12:10:21 2010 -0600
@@ -0,0 +1,446 @@
+/*
+===============================================================================
+
+ FILE: laszip.cpp
+
+ CONTENTS:
+
+ This tool reads and writes LIDAR data in the LAS format. Because our reader
+ and writer for the LAS format also support compression we can use this tool
+ to compress or decompress LIDAR files from standard *.las to our *.las.lz
+ or *.laz format.
+
+ PROGRAMMERS:
+
+ martin isenburg at cs.unc.edu
+
+ COPYRIGHT:
+
+ copyright (C) 2007-08 martin isenburg at cs.unc.edu
+
+ This software is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+ CHANGE HISTORY:
+
+ 12 March 2009 -- updated to ask for input if started without arguments
+ 17 September 2008 -- updated to deal with LAS format version 1.2
+ 14 February 2007 -- created after picking flowers for the Valentine dinner
+
+===============================================================================
+*/
+
+#include <time.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "lasreader.h"
+#include "laswriter.h"
+
+#ifdef _WIN32
+extern "C" FILE* fopenGzipped(const char* filename, const char* mode);
+#endif
+
+void usage(bool wait=false)
+{
+ fprintf(stderr,"usage:\n");
+ fprintf(stderr,"laszip lidar.las\n");
+ fprintf(stderr,"laszip lidar.laz\n");
+ fprintf(stderr,"laszip lidar.las lidar.las.lz\n");
+ fprintf(stderr,"laszip lidar.las.lz\n");
+ fprintf(stderr,"laszip -i lidar.las -o lidar_compressed.laz\n");
+ fprintf(stderr,"laszip -i lidar.las -olaz > lidar_compressed.laz\n");
+ fprintf(stderr,"laszip -h\n");
+ if (wait)
+ {
+ fprintf(stderr,"<press ENTER>\n");
+ getc(stdin);
+ }
+ exit(1);
+}
+
+static void byebye(bool wait=false)
+{
+ if (wait)
+ {
+ fprintf(stderr,"<press ENTER>\n");
+ getc(stdin);
+ }
+ exit(1);
+}
+
+static double taketime()
+{
+ return (double)(clock())/CLOCKS_PER_SEC;
+}
+
+int main(int argc, char *argv[])
+{
+ int i;
+ bool dry = false;
+ bool verbose = false;
+ char* file_name_in = 0;
+ char* file_name_out = 0;
+ bool ilas = false;
+ bool ilaz = false;
+ bool olas = false;
+ bool olaz = false;
+ bool range = true;
+ double start_time = 0;
+
+ if (argc == 1)
+ {
+ fprintf(stderr,"laszip.exe is better run in the command line\n");
+ file_name_in = new char[256];
+ fprintf(stderr,"enter input file: "); fgets(file_name_in, 256, stdin);
+ file_name_in[strlen(file_name_in)-1] = '\0';
+ file_name_out = new char[256];
+ fprintf(stderr,"enter output file: "); fgets(file_name_out, 256, stdin);
+ file_name_out[strlen(file_name_out)-1] = '\0';
+ }
+
+ for (i = 1; i < argc; i++)
+ {
+ if (strcmp(argv[i],"-dry") == 0)
+ {
+ dry = true;
+ }
+ else if (strcmp(argv[i],"-verbose") == 0)
+ {
+ verbose = true;
+ }
+ else if (strcmp(argv[i],"-range") == 0)
+ {
+ range = true;
+ }
+ else if (strcmp(argv[i],"-arithmetic") == 0 || strcmp(argv[i],"-arith") == 0)
+ {
+ range = false;
+ }
+ else if (strcmp(argv[i],"-h") == 0)
+ {
+ usage();
+ }
+ else if (strcmp(argv[i],"-i") == 0)
+ {
+ i++;
+ file_name_in = argv[i];
+ }
+ else if (strcmp(argv[i],"-o") == 0)
+ {
+ i++;
+ file_name_out = argv[i];
+ }
+ else if (strcmp(argv[i],"-ilas") == 0)
+ {
+ ilas = true;
+ }
+ else if (strcmp(argv[i],"-ilaz") == 0)
+ {
+ ilaz = true;
+ }
+ else if (strcmp(argv[i],"-olas") == 0)
+ {
+ olas = true;
+ }
+ else if (strcmp(argv[i],"-olaz") == 0)
+ {
+ olaz = true;
+ }
+ else if (i == argc - 2 && file_name_in == 0 && file_name_out == 0)
+ {
+ file_name_in = argv[i];
+ }
+ else if (i == argc - 1 && file_name_in == 0 && file_name_out == 0)
+ {
+ file_name_in = argv[i];
+ }
+ else if (i == argc - 1 && file_name_in != 0 && file_name_out == 0)
+ {
+ file_name_out = argv[i];
+ }
+ else
+ {
+ fprintf(stderr,"cannot understand argument '%s'\n", argv[i]);
+ usage();
+ }
+ }
+
+ // open input file
+
+ FILE* file_in = 0;
+ if (file_name_in)
+ {
+ if (strstr(file_name_in, ".gz"))
+ {
+#ifdef _WIN32
+ file_in = fopenGzipped(file_name_in, "rb");
+#else
+ fprintf(stderr, "ERROR: no support for gzipped input\n");
+ byebye(argc==1);
+#endif
+ }
+ else
+ {
+ file_in = fopen(file_name_in, "rb");
+ }
+ if (file_in == 0)
+ {
+ fprintf(stderr, "ERROR: could not open '%s'\n",file_name_in);
+ byebye(argc==1);
+ }
+ }
+ else if (ilas || ilaz)
+ {
+ file_in = stdin;
+ }
+ else
+ {
+ fprintf(stderr, "ERROR: no input specified\n");
+ usage(argc==1);
+ }
+
+ LASreader* lasreader = new LASreader();
+
+ if (!lasreader->open(file_in))
+ {
+ fprintf(stderr, "ERROR: could not open lasreader\n");
+ byebye(argc==1);
+ }
+
+ // maybe only a read pass
+
+ if (dry)
+ {
+ LASpoint point_min;
+ LASpoint point_max;
+ double gps_time_min = 0;
+ double gps_time_max = 0;
+ short rgb_min[3] = {0,0,0};
+ short rgb_max[3] = {0,0,0};
+
+ start_time = taketime();
+
+ if (verbose)
+ {
+ lasreader->read_point();
+ point_min = lasreader->point;
+ point_max = lasreader->point;
+ if (lasreader->points_have_gps_time)
+ {
+ gps_time_min = lasreader->gps_time;
+ gps_time_max = lasreader->gps_time;
+ }
+ if (lasreader->points_have_rgb)
+ {
+ rgb_min[0] = lasreader->rgb[0];
+ rgb_min[1] = lasreader->rgb[1];
+ rgb_min[2] = lasreader->rgb[2];
+ rgb_max[0] = lasreader->rgb[0];
+ rgb_max[1] = lasreader->rgb[1];
+ rgb_max[2] = lasreader->rgb[2];
+ }
+ while (lasreader->read_point())
+ {
+ if (lasreader->point.x < point_min.x) point_min.x = lasreader->point.x;
+ else if (lasreader->point.x > point_max.x) point_max.x = lasreader->point.x;
+ if (lasreader->point.y < point_min.y) point_min.y = lasreader->point.y;
+ else if (lasreader->point.y > point_max.y) point_max.y = lasreader->point.y;
+ if (lasreader->point.z < point_min.z) point_min.z = lasreader->point.z;
+ else if (lasreader->point.z > point_max.z) point_max.z = lasreader->point.z;
+ if (lasreader->point.intensity < point_min.intensity) point_min.intensity = lasreader->point.intensity;
+ else if (lasreader->point.intensity > point_max.intensity) point_max.intensity = lasreader->point.intensity;
+ if (lasreader->point.edge_of_flight_line < point_min.edge_of_flight_line) point_min.edge_of_flight_line = lasreader->point.edge_of_flight_line;
+ else if (lasreader->point.edge_of_flight_line > point_max.edge_of_flight_line) point_max.edge_of_flight_line = lasreader->point.edge_of_flight_line;
More information about the Liblas-commits
mailing list