Sha256: bcc3a54145f20464cd9aa56d5e9d65eaf25646cebcc32967d85a76151de5f3e4

Contents?: true

Size: 1.81 KB

Versions: 6

Compression:

Stored size: 1.81 KB

Contents

# frozen_string_literal: true

module GDAL
  module Transformers
    class GCPTransformer
      # @return [FFI::Function]
      def self.function
        FFI::GDAL::Alg::GCPTransform
      end

      # @param pointer [FFI::Pointer]
      def self.release(pointer)
        return unless pointer && !pointer.null?

        FFI::GDAL::Alg.GDALDestroyGCPTransformer(pointer)
      end

      # @return [FFI::Pointer] C pointer to the GCP transformer.
      attr_reader :c_pointer

      # @param gcp_list [Array<FFI::GDAL::GCP>]
      # @param requested_polynomial_order [Integer] 1, 2, or 3.
      # @param reversed [Boolean]
      def initialize(gcp_list, requested_polynomial_order, reversed: false, tolerance: nil, minimum_gcps: nil)
        gcp_list_ptr = FFI::MemoryPointer.new(:pointer, gcp_list.size)

        # TODO: fasterer: each_with_index is slower than loop
        gcp_list.each_with_index do |gcp, i|
          gcp_list_ptr[i].put_pointer(0, gcp.to_ptr)
        end

        pointer = if tolerance || minimum_gcps
                    FFI::GDAL::Alg.GDALCreateGCPRefineTransformer(
                      gcp_list.size,
                      gcp_list_ptr,
                      requested_polynomial_order,
                      reversed
                    )
                  else
                    FFI::GDAL::Alg.GDALCreateGCPTransformer(
                      gcp_list.size,
                      gcp_list_ptr,
                      requested_polynomial_order,
                      reversed
                    )
                  end

        @c_pointer = FFI::AutoPointer.new(pointer, GCPTransformer.method(:release))
      end

      def destroy!
        GCPTransformer.release(@c_pointer)

        @c_pointer = nil
      end

      # @return [FFI::Function]
      def function
        self.class.function
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
ffi-gdal-1.1.0 lib/gdal/transformers/gcp_transformer.rb
ffi-gdal-1.0.4 lib/gdal/transformers/gcp_transformer.rb
ffi-gdal-1.0.3 lib/gdal/transformers/gcp_transformer.rb
ffi-gdal-1.0.2 lib/gdal/transformers/gcp_transformer.rb
ffi-gdal-1.0.1 lib/gdal/transformers/gcp_transformer.rb
ffi-gdal-1.0.0 lib/gdal/transformers/gcp_transformer.rb