Skip to main content

WasmCogViewer

Struct WasmCogViewer 

Source
pub struct WasmCogViewer { /* private fields */ }
Expand description

WASM-compatible COG (Cloud Optimized GeoTIFF) viewer

This is the basic COG viewer for browser-based geospatial data visualization. It provides simple access to COG metadata and tile reading functionality.

§Features

  • Efficient tile-based access to large GeoTIFF files
  • Support for multi-band imagery
  • Overview/pyramid level access for different zoom levels
  • CORS-compatible HTTP range request support
  • Automatic TIFF header parsing
  • GeoTIFF metadata extraction (CRS, geotransform, etc.)

§Performance

The viewer uses HTTP range requests to fetch only the required portions of the file, making it efficient for large files. However, for production use cases with caching and advanced features, consider using AdvancedCogViewer instead.

§Example

const viewer = new WasmCogViewer();
await viewer.open('<https://example.com/image.tif>');
console.log(`Size: ${viewer.width()}x${viewer.height()}`);
const tile = await viewer.read_tile_as_image_data(0, 0, 0);

Implementations§

Source§

impl WasmCogViewer

Source

pub fn new() -> Self

Creates a new COG viewer

Source

pub async fn open(&mut self, url: &str) -> Result<(), JsValue>

Opens a COG file from a URL

This method performs the following operations:

  1. Sends a HEAD request to determine file size and range support
  2. Fetches the TIFF header to validate format
  3. Parses IFD (Image File Directory) to extract metadata
  4. Extracts GeoTIFF tags for coordinate system information
  5. Counts overview levels for multi-resolution support
§Arguments
  • url - The URL of the COG file to open. Must support HTTP range requests for optimal performance. CORS must be properly configured.
§Returns

Returns Ok(()) on success, or a JavaScript error on failure.

§Errors

This method can fail for several reasons:

  • Network errors (no connection, timeout, etc.)
  • HTTP errors (404, 403, 500, etc.)
  • CORS errors (missing headers)
  • Invalid TIFF format
  • Unsupported TIFF variant
§Example
const viewer = new WasmCogViewer();
try {
    await viewer.open('<https://example.com/landsat.tif>');
    console.log('Successfully opened COG');
} catch (error) {
    console.error('Failed to open:', error);
}
Source

pub fn width(&self) -> u64

Returns the image width

Source

pub fn height(&self) -> u64

Returns the image height

Source

pub fn tile_width(&self) -> u32

Returns the tile width

Source

pub fn tile_height(&self) -> u32

Returns the tile height

Source

pub fn band_count(&self) -> u32

Returns the number of bands

Source

pub fn overview_count(&self) -> usize

Returns the number of overview levels

Source

pub fn epsg_code(&self) -> Option<u32>

Returns the EPSG code if available

Source

pub fn url(&self) -> Option<String>

Returns the URL

Source

pub fn metadata_json(&self) -> String

Returns metadata as JSON

Source

pub fn pixel_scale_x(&self) -> Option<f64>

Returns pixel scale X (degrees/pixel in lon direction)

Source

pub fn pixel_scale_y(&self) -> Option<f64>

Returns pixel scale Y (degrees/pixel in lat direction, negative)

Source

pub fn tiepoint_geo_x(&self) -> Option<f64>

Returns tiepoint geo X (top-left longitude)

Source

pub fn tiepoint_geo_y(&self) -> Option<f64>

Returns tiepoint geo Y (top-left latitude)

Source

pub async fn read_tile( &self, _level: usize, tile_x: u32, tile_y: u32, ) -> Result<Vec<u8>, JsValue>

Reads a tile and returns raw bytes

Source

pub async fn read_tile_as_image_data( &self, level: usize, tile_x: u32, tile_y: u32, ) -> Result<ImageData, JsValue>

Reads a tile and converts to RGBA ImageData for canvas rendering

Trait Implementations§

Source§

impl Default for WasmCogViewer

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl From<WasmCogViewer> for JsValue

Source§

fn from(value: WasmCogViewer) -> Self

Converts to this type from the input type.
Source§

impl FromWasmAbi for WasmCogViewer

Source§

type Abi = u32

The Wasm ABI type that this converts from when coming back out from the ABI boundary.
Source§

unsafe fn from_abi(js: u32) -> Self

Recover a Self from Self::Abi. Read more
Source§

impl IntoWasmAbi for WasmCogViewer

Source§

type Abi = u32

The Wasm ABI type that this converts into when crossing the ABI boundary.
Source§

fn into_abi(self) -> u32

Convert self into Self::Abi so that it can be sent across the wasm ABI boundary.
Source§

impl LongRefFromWasmAbi for WasmCogViewer

Source§

type Abi = u32

Same as RefFromWasmAbi::Abi
Source§

type Anchor = RcRef<WasmCogViewer>

Same as RefFromWasmAbi::Anchor
Source§

unsafe fn long_ref_from_abi(js: Self::Abi) -> Self::Anchor

Same as RefFromWasmAbi::ref_from_abi
Source§

impl OptionFromWasmAbi for WasmCogViewer

Source§

fn is_none(abi: &Self::Abi) -> bool

Tests whether the argument is a “none” instance. If so it will be deserialized as None, and otherwise it will be passed to FromWasmAbi.
Source§

impl OptionIntoWasmAbi for WasmCogViewer

Source§

fn none() -> Self::Abi

Returns an ABI instance indicating “none”, which JS will interpret as the None branch of this option. Read more
Source§

impl RefFromWasmAbi for WasmCogViewer

Source§

type Abi = u32

The Wasm ABI type references to Self are recovered from.
Source§

type Anchor = RcRef<WasmCogViewer>

The type that holds the reference to Self for the duration of the invocation of the function that has an &Self parameter. This is required to ensure that the lifetimes don’t persist beyond one function call, and so that they remain anonymous.
Source§

unsafe fn ref_from_abi(js: Self::Abi) -> Self::Anchor

Recover a Self::Anchor from Self::Abi. Read more
Source§

impl RefMutFromWasmAbi for WasmCogViewer

Source§

type Abi = u32

Same as RefFromWasmAbi::Abi
Source§

type Anchor = RcRefMut<WasmCogViewer>

Same as RefFromWasmAbi::Anchor
Source§

unsafe fn ref_mut_from_abi(js: Self::Abi) -> Self::Anchor

Same as RefFromWasmAbi::ref_from_abi
Source§

impl TryFromJsValue for WasmCogViewer

Source§

fn try_from_js_value(value: JsValue) -> Result<Self, JsValue>

Performs the conversion.
Source§

fn try_from_js_value_ref(value: &JsValue) -> Option<Self>

Performs the conversion.
Source§

impl VectorFromWasmAbi for WasmCogViewer

Source§

impl VectorIntoWasmAbi for WasmCogViewer

Source§

impl WasmDescribe for WasmCogViewer

Source§

impl WasmDescribeVector for WasmCogViewer

Source§

impl SupportsConstructor for WasmCogViewer

Source§

impl SupportsInstanceProperty for WasmCogViewer

Source§

impl SupportsStaticProperty for WasmCogViewer

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> ReturnWasmAbi for T
where T: IntoWasmAbi,

Source§

type Abi = <T as IntoWasmAbi>::Abi

Same as IntoWasmAbi::Abi
Source§

fn return_abi(self) -> <T as ReturnWasmAbi>::Abi

Same as IntoWasmAbi::into_abi, except that it may throw and never return in the case of Err.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T> Upcast<T> for S
where T: UpcastFrom<S> + ?Sized, S: ?Sized,

Source§

fn upcast(&self) -> &T
where Self: ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider ref type within the Wasm bindgen generics type system. Read more
Source§

fn upcast_into(self) -> T
where Self: Sized + ErasableGeneric, T: ErasableGeneric<Repr = Self::Repr>,

Perform a zero-cost type-safe upcast to a wider type within the Wasm bindgen generics type system. Read more
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more