Sha256: 93d5c34f8eeb6df0d9b2fdeefe50678e41dc0b4cfbbb31410d7f52abee847bc3

Contents?: true

Size: 1.96 KB

Versions: 5

Compression:

Stored size: 1.96 KB

Contents

module Mittsu
  module ImageUtils
    class << self
      def load_texture(url, mapping = Texture::DEFAULT_MAPPING)
        loader = ImageLoader.new

        Texture.new(nil, mapping).tap do |texture|
          image = loader.load(url, flip: true)
          texture.image = image
          texture.needs_update = true

          texture.source_file = url
        end
      end

      def load_texture_cube(array, mapping = Texture::DEFAULT_MAPPING)
        images = HashArray.new

        loader = ImageLoader.new
        CubeTexture.new(images, mapping).tap do |texture|
          loaded = 0

          array.length.times do |i|
            texture.images[i] = loader.load(array[i])
            loaded += 1
            if loaded == 6
              texture.needs_update = true
            end
          end
        end
      end

      def get_normal_map(image, depth)
        # adapted from http://www.paulbrunt.co.uk/lab/heightnormal/

        # depth |= 1
        #
        # width = image.width
        # height = image.height

        # TODO: original version uses browser features ...
      end

      def generate_data_texture(width, height, color)
        size = width * height
        data = Array.new(3 * size) # Uint8Array

        r = (color.r * 255).floor
        g = (color.g * 255).floor
        b = (color.b * 255).floor

        size.times do |i|
          data[i * 3]     = r
          data[i * 3 + 1] = g
          data[i * 3 + 2] = b
        end

        texture = DataTexture.new(data, width, height, RGBFormat)
        texture.needs_update = true

        texture
      end

      private

      def cross(a, b)
        [
          a[1] * b[2] - a[2] * b[1],
          a[2] * b[0] - a[0] * b[2],
          a[0] * b[1] - a[1] * b[0]
        ]
      end

      def subtract(a, b)
        [a[0] - b[0], a[1] - b[1], a[2] - b[2]]
      end

      def normalize(a)
        l = Math.sqrt(a[0] * a[0] + a[1] * a[1] + a[2] * a[2])
        [a[0] / l, a[1] / l, a[2] / l]
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
mittsu-0.1.5 lib/mittsu/extras/image_utils.rb
mittsu-0.1.4 lib/mittsu/extras/image_utils.rb
mittsu-0.1.3 lib/mittsu/extras/image_utils.rb
mittsu-0.1.2 lib/mittsu/extras/image_utils.rb
mittsu-0.1.1 lib/mittsu/extras/image_utils.rb