165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn/* 265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * Copyright (C) 2011 The Android Open Source Project 365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * 465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * Licensed under the Apache License, Version 2.0 (the "License"); 565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * you may not use this file except in compliance with the License. 665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * You may obtain a copy of the License at 765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * 865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * http://www.apache.org/licenses/LICENSE-2.0 965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * 1065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * Unless required by applicable law or agreed to in writing, software 1165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * distributed under the License is distributed on an "AS IS" BASIS, 1265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * See the License for the specific language governing permissions and 1465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn * limitations under the License. 1565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn */ 1665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 1765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn#ifndef ANDROID_FILTERFW_FILTERPACKS_BASE_GEOMETRY_H 1865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn#define ANDROID_FILTERFW_FILTERPACKS_BASE_GEOMETRY_H 1965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 2065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn#include <vector> 2165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 2265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennnamespace android { 2365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennnamespace filterfw { 2465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 2565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn// This is an initial implementation of some geometrical structures. This is 2665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn// likely to grow and become more sophisticated in the future. 2765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 2865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennclass Point { 2965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn public: 3065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Point() : x_(0.0f), y_(0.0f) {} 3165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Point(float x, float y) : x_(x), y_(y) {} 3265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 3365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float x() const { return x_; } 3465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float y() const { return y_; } 3565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 3665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float Length() const; 3765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn bool ScaleTo(float new_length); 3865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn static float Distance(const Point& p0, const Point& p1); 3965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 4065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn // Add more of these as needed: 4165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Point operator+(const Point& other) const; 4265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Point operator-(const Point& other) const; 4365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Point operator*(float factor) const; 4465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 4565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn void Rotate90Clockwise(); 4665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 4765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn private: 4865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float x_, y_; 4965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn}; 5065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 5165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennclass Quad { 5265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn public: 5365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Quad() : points_(4) {} 5465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn virtual ~Quad() {} 5565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 5665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Quad(const Point& p0, const Point& p1, const Point& p2, const Point& p3) 5765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn : points_(4) { 5865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn points_[0] = p0; 5965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn points_[1] = p1; 6065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn points_[2] = p2; 6165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn points_[3] = p3; 6265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn } 6365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 6465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn const std::vector<Point>& points() const { return points_; } 6565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn const Point& point(int ix) const; 6665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 6765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn protected: 6865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn std::vector<Point> points_; 6965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn}; 7065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 7165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennclass SlantedRect : public Quad { 7265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn public: 7365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn SlantedRect() : width_(0.0f), height_(0.0f) {} 7465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn virtual ~SlantedRect() {} 7565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 7665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn bool FromCenterAxisAndLengths(const Point& center, 7765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn const Point& vert_axis, 7865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn const Point& lenghts); 7965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 8065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float width() const { return width_; } 8165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float height() const { return height_; } 8265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 8365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn private: 8465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float width_; 8565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float height_; 8665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn}; 8765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 8865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Rennstruct Rect { 8965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn float x, y, width, height; 9065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 9165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Rect() { 9265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn x = y = 0.0f; 9365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn width = height = 1.0f; 9465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn } 9565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 9665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn Rect(float x, float y, float width, float height) { 9765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn this->x = x; 9865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn this->y = y; 9965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn this->width = width; 10065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn this->height = height; 10165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn } 10265953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 10365953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn bool ExpandToAspectRatio(float ratio); 10465953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn bool ExpandToMinLength(float length); 10565953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn bool ScaleWithLengthLimit(float factor, float max_length); 10665953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn}; 10765953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 10865953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn} // namespace filterfw 10965953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn} // namespace android 11065953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn 11165953da4636fbf5f0a24b8f5f2b5fa7d76ff13d9Marius Renn#endif // ANDROID_FILTERFW_FILTERPACKS_BASE_GEOMETRY_H 112