Sha256: f90ecdea4c8786de40510d302660698110cfe5c7ba439dd5bf680b3f22227ceb

Contents?: true

Size: 1.32 KB

Versions: 2

Compression:

Stored size: 1.32 KB

Contents

module NSWTopo
  module Formats
    def render_gemf(gemf_path, name:, **options, &block)
      Dir.mktmppath do |temp_dir|
        ranges = tiled_web_map(temp_dir, **options, extension: "gemf", &block).sort_by do |tile|
          [tile.col, tile.row]
        end.group_by(&:zoom)

        header, source = "", "nswtopo"
        # 3.1 overall header:
        header << [4, 256].pack("L>L>")
        # 3.2 sources:
        header << [1, 0, source.bytesize, source].pack("L>L>L>a#{source.bytesize}")
        # 3.3 number of ranges:
        header << [ranges.length].pack("L>")

        offset = header.bytesize + ranges.size * 32
        paths = ranges.each do |zoom, tiles|
          cols = tiles.map(&:col)
          rows = tiles.map(&:row)
          # 3.3 range data:
          header << [zoom, *cols.minmax, *rows.minmax, 0, offset].pack("L>L>L>L>L>L>Q>")
          offset += tiles.size * 12
        end.each do |zoom, tiles|
          # 3.4 range details:
          tiles.each do |tile|
            header << [offset, tile.path.size].pack("Q>L>")
            offset += tile.path.size
          end
        end.values.flatten.map(&:path)

        gemf_path.open("wb") do |file|
          file.write header
          # 4 data area:
          paths.each do |path|
            file.write path.binread
          end
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
nswtopo-3.0.1 lib/nswtopo/formats/gemf.rb
nswtopo-3.0 lib/nswtopo/formats/gemf.rb