Struct las::header::Header

source ·
pub struct Header { /* private fields */ }
Expand description

Metadata describing the layout, source, and interpretation of the points.

Headers include all las metadata, including regular and extended variable length records and any file padding (e.g. extra bytes after the header).

Implementations§

Creates a new header from a raw header.

Examples
use las::{raw, Header};
let raw_header = raw::Header::default();
let header = Header::from_raw(raw_header).unwrap();

Clears this header’s point counts and bounds.

Examples
use las::{Header, Point, Bounds};
let mut header = Header::default();
header.add_point(&Point { return_number: 1, ..Default::default() });
assert_eq!(1, header.number_of_points());
assert_eq!(1, header.number_of_points_by_return(1).unwrap());
header.clear();
assert_eq!(0, header.number_of_points());
assert_eq!(None, header.number_of_points_by_return(1));
assert_eq!(Bounds::default(), header.bounds());

Adds a point to this header, incrementing the point counts and growing the bounds.

Examples
use las::Header;
let mut header = Header::default();
header.add_point(&Default::default());
assert_eq!(1, header.number_of_points());

Returns this header’s file source id.

For airborne data, this is often the flight line number.

Examples
use las::Header;
assert_eq!(0, Header::default().file_source_id());

Returns the gps time type.

This affects what the gps time values on points means. GpsTimeType::Week means that the time values are seconds from the start of the week. GpsTimeType::Standard means that the time values are standard GPS time (satellite gps time) minus 10e9.

Examples
use las::{GpsTimeType, Header};
assert_eq!(GpsTimeType::Week, Header::default().gps_time_type());

Returns true if the return numbers on the point data records have been synthetically generated.

Only supported in later las versions.

Examples
use las::Header;
assert!(!Header::default().has_synthetic_return_numbers());

Returns this header’s guid.

Examples
use las::Header;
let guid = Header::default().guid();

Returns this header’s version.

Examples
use las::{Header, Version};
assert_eq!(Version::new(1, 2), Header::default().version());

Returns this header’s system identifier.

Describes the source of the data, whether it is a sensor or a processing operation.

Examples
use las::Header;
println!("{}", Header::default().system_identifier());

Returns this header’s generating software.

Examples
use las::Header;
assert!(Header::default().generating_software().starts_with("las-rs"));

Returns this header’s file creation date.

Can be None, which is against spec but happens with files in the wild.

Examples
use las::Header;
let date = Header::default().date().unwrap();

Returns this header’s padding.

These are bytes that are after the header but before the vlr. Not recommended to use.

Examples
use las::Header;
assert!(Header::default().padding().is_empty());

Returns this header’s point format.

Point formats are used to describe the attributes and extra bytes of each point.

Examples
use las::Header;
let header = Header::default();
assert_eq!(0, header.point_format().to_u8().unwrap());

Returns this header’s transforms.

The transforms are the scales and offsets used to convert floating point numbers to i16. Las data stores point coordinates as i16s internally.

Examples
use las::Header;
let header = Header::default();
let transforms = header.transforms();
assert_eq!(0.001, transforms.x.scale);

Returns the bounds of this header.

The bounds describe the min and max values in each dimension.

Examples
use las::Header;
let bounds = Header::default().bounds();

Returns this header’s number of points.

Examples
use las::Header;
let header = Header::default();
assert_eq!(0, header.number_of_points());

Returns this header’s number of points for a given return number.

Note that return numbers are 1-indexed.

Examples
use las::Header;
let header = Header::default();
assert_eq!(None, header.number_of_points_by_return(1));

Returns a reference to this header’s vlr padding.

These are bytes after the vlrs but before the points. Again, not recommended for use.

Examples
use las::Header;
assert!(Header::default().vlr_padding().is_empty());

Returns a reference to this header’s point padding.

These are the bytes after the points but before eof/any evlrs. Not recommended.

Examples
use las::Header;
assert!(Header::default().point_padding().is_empty());

Returns a reference to this header’s vlrs.

Examples
use las::{Vlr, Builder};
let mut builder = Builder::default();
builder.vlrs.push(Vlr::default());
let header = builder.into_header().unwrap();
assert_eq!(1, header.vlrs().len());

Returns a reference to header’s extended variable length records.

Examples
use las::{Vlr, Builder};
let mut builder = Builder::from((1, 4));
builder.evlrs.push(Vlr::default());
let header = builder.into_header().unwrap();
assert_eq!(1, header.evlrs().len());

Returns an iterator over all this header’s vlrs, both extended and regular.

Examples
use las::{Vlr, Builder};
let mut builder = Builder::from((1, 4));
builder.vlrs.push(Vlr::default());
builder.evlrs.push(Vlr::default());
let header = builder.into_header().unwrap();
assert_eq!(2, header.all_vlrs().count());

Converts this header into a raw header.

Examples
use las::Header;
let raw_header = Header::default().into_raw().unwrap();

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Returns the “default value” for a type. Read more
Converts to this type from the input type.
Converts to this type from the input type.
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.