Sha256: 82a544bb398ec7804b2d07798b24b128ce0be622367accbfba79e4a847e2cfee

Contents?: true

Size: 1.56 KB

Versions: 2

Compression:

Stored size: 1.56 KB

Contents

require 'json'

module OGR
  module GeometryExtensions
    # @return [Hash]
    def as_json(options = nil)
      json = {
        coordinate_dimension: coordinate_dimension,
        geometry_count: geometry_count,
        dimension: dimension,
        is_empty: empty?,
        is_ring: ring?,
        is_simple: simple?,
        is_valid: valid?,
        name: name,
        point_count: point_count,
        spatial_reference: spatial_reference.nil? ? nil : spatial_reference.as_json(options),
        type: type_to_name,
        wkb_size: wkb_size
      }

      json.merge!(area: area) if respond_to? :area
      json.merge!(length: length) if respond_to? :length
      json.merge!(points: points) if respond_to? :points

      json
    end

    # @return [String]
    def to_json(options = nil)
      as_json(options).to_json
    end

    def collection?
      false
    end

    def to_vector(file_name, driver, layer_name: 'vectorized_geometry', spatial_reference: nil)
      driver = OGR::Driver.by_name(driver)

      data_source = driver.create_data_source(file_name)
      log "Creating layer #{layer_name}, type: #{type}"
      layer = data_source.create_layer(layer_name, geometry_type: type,
                                                   spatial_reference: spatial_reference)

      # field = FieldDefinition.new('Name', :OFTString)
      # field.width = 32

      unless layer
        fail OGR::InvalidLayer, "Unable to create layer '#{layer_name}'."
      end

      feature = layer.create_feature(layer_name)
      feature.geometry = self

      data_source
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ffi-gdal-1.0.0.beta5 lib/ogr/geometry_extensions.rb
ffi-gdal-1.0.0.beta4 lib/ogr/geometry_extensions.rb