/* * Copyright (C) 2013 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. */ #include "Vector2D.h" #include <math.h> Vector2D::Vector2D() : mX(0), mY(0) { } Vector2D::Vector2D(float x, float y) : mX(x), mY(y) { } Vector2D Vector2D::copy() { Vector2D v(mX, mY); return v; } void Vector2D::add(const Vector2D& v) { mX += v.mX; mY += v.mY; } void Vector2D::sub(const Vector2D& v) { mX -= v.mX; mY -= v.mY; } void Vector2D::scale(float s) { mX *= s; mY *= s; } float Vector2D::distance(const Vector2D& v) { float dx = mX - v.mX; float dy = mY - v.mY; return (float) sqrt(dx * dx + dy * dy); } void Vector2D::normalize() { float m = magnitude(); if (m > 0) { scale(1 / m); } } void Vector2D::limit(float max) { if (magnitude() > max) { normalize(); scale(max); } } float Vector2D::magnitude() { return (float) sqrt(mX * mX + mY * mY); }