Sha256: c47ecd448e6c8aafc426c6a4400213331bc89238e0bb6ed186021cae8302aa5b

Contents?: true

Size: 1.92 KB

Versions: 5

Compression:

Stored size: 1.92 KB

Contents

module Mittsu
  class Line3
    attr_accessor :start_point, :end_point

    def initialize(start_point = Mittsu::Vector3.new, end_point = Mittsu::Vector3.new)
      @start_point, @end_point = start_point, end_point
    end

    def set(start_point, end_point)
      @start_point.copy(start_point)
      @end_point.copy(end_point)
      self
    end

    def copy(line)
      @start_point.copy(line.start_point)
      @end_point.copy(line.end_point)
      self
    end

    def center(target = Mittsu::Vector3.new)
      target.add_vectors(@start_point, @end_point).multiply_scalar(0.5)
    end

    def delta(target = Mittsu::Vector3.new)
      target.sub_vectors(@end_point, @start_point)
    end

    def distance_sq
      @start_point.distance_to_squared(@end_point)
    end

    def distance
      @start_point.distance_to(@end_point)
    end

    def at(t, target = Mittsu::Vector3.new)
      self.delta(target).multiply_scalar(t).add(self.start_point)
    end

    def closest_point_to_point_parameter(point, clamp_to_line)
      start_p = Mittsu::Vector3.new
      start_end = Mittsu::Vector3.new
      start_p.sub_vectors(point, @start_point)
      start_end.sub_vectors(@end_point, @start_point)
      start_end2 = start_end.dot(start_end)
      start_end_start_p = start_end.dot(start_p)
      t = start_end_start_p / start_end2
      if clamp_to_line
        t = Math.clamp(t, 0.0, 1.0)
      end
      t
    end

    def closest_point_to_point(point, clamp_to_line, target = Mittsu::Vector3.new)
      t = self.closest_point_to_point_parameter(point, clamp_to_line)
      self.delta(target).multiply_scalar(t).add(self.start_point)
    end

    def apply_matrix4(matrix)
      @start_point.apply_matrix4(matrix)
      @end_point.apply_matrix4(matrix)
      self
    end

    def equals(line)
      line.start_point.equals(@start_point) && line.end_point.equals(@end_point)
    end

    def clone
      Mittsu::Line3.new.copy(self)
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
mittsu-0.5.0 lib/mittsu/math/line3.rb
mittsu-0.4.1 lib/mittsu/math/line3.rb
mittsu-0.4.0 lib/mittsu/math/line3.rb
mittsu-0.3.3 lib/mittsu/math/line3.rb
mittsu-0.3.2 lib/mittsu/math/line3.rb