Logo Search packages:      
Sourcecode: parsec47 version File versions  Download package

Vector.d

/*
 * $Id: Vector.d,v 1.2 2004/01/01 11:26:43 kenta Exp $
 *
 * Copyright 2003 Kenta Cho. All rights reserved.
 */
module abagames.util.Vector;

private:
import std.math;

/**
 * Vector.
 */
00014 public class Vector {
 public:
  float x, y;

 private:

  public this() {}

  public this(float x, float y) {
    this.x = x; this.y = y;
  }

  public float innerProduct(Vector v) {
    return x * v.x + y * v.y;
  }

  public Vector getElement(Vector v) {
    Vector rsl;
    float ll = v.x * v.x + v.y * v.y;
    if (ll != 0) {
      float mag = innerProduct(v);
      rsl.x = mag * v.x / ll;
      rsl.y = mag * v.y / ll;
    } else {
      rsl.x = rsl.y = 0; 
    }
    return rsl;
  }

  public void add(Vector v) {
    x += v.x;
    y += v.y;
  }

  public void sub(Vector v) {
    x -= v.x;
    y -= v.y;
  }

  public void mul(float a) {  
    x *= a;
    y *= a;
  }

  public void div(float a) {  
    x /= a;
    y /= a;
  }

  public float checkSide(Vector pos1, Vector pos2) {
    float xo = pos2.x - pos1.x;
    float yo = pos2.y - pos1.y;
    if (xo == 0) {
      if (yo == 0)
      return 0;
      if (yo > 0)
      return x - pos1.x;
      else
      return pos1.x - x;
    } else if (yo == 0) {
      if (xo > 0)
      return pos1.y - y;
      else
      return y - pos1.y;
    } else {
      if (xo * yo > 0) { 
      return (x - pos1.x) / xo - (y - pos1.y) / yo;
      } else {
      return -(x - pos1.x) / xo + (y - pos1.y) / yo;
      }
    }
  }

  public float checkSide(Vector pos1, Vector pos2, Vector ofs) {
    float xo = pos2.x - pos1.x;
    float yo = pos2.y - pos1.y;
    float mx = x - ofs.x;
    float my = y - ofs.y;
    if (xo == 0) {
      if (yo == 0)
      return 0;
      if (yo > 0)
      return mx - pos1.x;
      else
      return pos1.x - mx;
    } else if (yo == 0) {
      if (xo > 0)
      return pos1.y - my;
      else
      return my - pos1.y;
    } else {
      if (xo * yo > 0) { 
      return (mx - pos1.x) / xo - (my - pos1.y) / yo;
      } else {
      return -(mx - pos1.x) / xo + (my - pos1.y) / yo;
      }
    }
  }

  public float size() {
    return sqrt(x * x + y * y);
  }

  public float dist(Vector v) {
    float ax = fabs(x - v.x);
    float ay = fabs(y - v.y);
    if ( ax > ay ) {
      return ax + ay / 2;
    } else {
      return ay + ax / 2;
    }
  }
}

Generated by  Doxygen 1.6.0   Back to index