Socket
Book a DemoInstallSign in
Socket

spherical_mercator

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

spherical_mercator

1.2.0
bundlerRubygems
Version published
Maintainers
1
Created
Source

Ruby port of Mapbox Spherical Mercator

Gem Version Build Status Coverage Status License

Spherical Mercator gem is a port of Mapbox sphericalmercator JS lib that provides projection math for converting between mercator meters, screen pixels (of 256x256 or configurable-size tiles), and latitude/longitude.

Requirements

  • Ruby >= 2.0

Installation

Simple:

gem install spherical_mercator

For Gemfile:

gem 'spherical_mercator'

API

NOTE: API description copied from the original repo.

Some datatypes are assumed to be arrays: ll is [lon, lat], xy and px are [x, y].

# By default, precomputes up to z30
mercator = SphericalMercator.new(size: 256)
# Whether to round pixel values at integer zoom levels. Defaults to true.
mercator = SphericalMercator.new(round: false)

px(lon_lat, zoom)

Convert lon, lat to screen pixel x, y from 0, 0 origin, at a certain zoom level. The inverse of ll

Screen pixel values are rounded, unless the zoom level is a floating point value. To disable rounding on integer zoom levels, specify round: false when creating the SphericalMercator.

ll(px, zoom)

Convert screen pixel value to lon, lat, at a certain zoom level. The inverse of px

bbox(x, y, zoom, tms_style, srs)

Convert tile xyz value to bbox of the form [west, south, east, north]

  • x {Number} x (longitude) number.
  • y {Number} y (latitude) number.
  • zoom {Number} zoom.
  • tms_style {Boolean} whether to compute using tms-style. (optional, default false)
  • srs {String} projection for resulting bbox ('WGS84'|'900913'). (optional, default 'WGS84')

Returns bbox array of values in form [west, south, east, north].

xyz(bbox, zoom, tms_style, srs)

Convert bbox to xyz bounds

  • bbox {Number} bbox in the form [west, south, east, north].
  • zoom {Number} zoom.
  • tms_style {Boolean} whether to compute using tms-style. (optional, default false)
  • srs {String} projection of input bbox ('WGS84'|'900913'). (optional, default 'WGS84')

Returns Hash object ({...}) for XYZ bounds containing :minX, :maxX, :minY, :maxY properties.

convert(bbox, to)

Convert bbox from 900913 to WGS84 or vice versa

  • bbox {Number} bbox in the form [west, south, east, north].
  • to {String} projection of resulting bbox ('WGS84'|'900913'). (optional, default 'WGS84')

Returns bbox array of values in form [west, south, east, north].

forward(lon_lat)

Convert lon, lat values (must be an array like [lon, lat]) to mercator x, y

inverse(xy)

Convert mercator x, y values (xy must be an array like [x, y]) to lon, lat

Contributing

You are very welcome to help improve spherical_mercator if you have suggestions for features that other people can use.

To contribute:

  • Fork the project.
  • Create your feature branch (git checkout -b my-new-feature).
  • Implement your feature or bug fix.
  • Add documentation for your feature or bug fix.
  • Run rake doc:yard. If your changes are not 100% documented, go back to step 4.
  • Add tests for your feature or bug fix.
  • Run rake to make sure all tests pass.
  • Commit your changes (git commit -am 'Add new feature').
  • Push to the branch (git push origin my-new-feature).
  • Create new pull request.

Thanks.

License

Spherical Mercator gem is released under the MIT License.

Copyright (c) 2017 Nikita Bulai (bulajnikita@gmail.com) and original lib authors.

FAQs

Package last updated on 10 Feb 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.