/* * PROJECT: FLARToolkitAS3 * -------------------------------------------------------------------------------- * This work is based on the original ARToolKit developed by * Hirokazu Kato * Mark Billinghurst * HITLab, University of Washington, Seattle * http://www.hitl.washington.edu/artoolkit/ * * The FLARToolkitAS3 is AS3 edition ARToolKit class library. * Copyright (C)2010 Ryo Iizuka * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * * For further information please contact. * http://nyatla.jp/nyatoolkit/ * or * */ package org.libspark.flartoolkit.core.utils { import org.libspark.flartoolkit.core.types.*; public class FLARPerspectiveParamGenerator_O1 extends FLARPerspectiveParamGenerator { /** * コンストラクタです。 * @param i_local_x * パラメータ計算の基準点を指定します。 * @param i_local_y * パラメータ計算の基準点を指定します。 */ public function FLARPerspectiveParamGenerator_O1(i_local_x:int,i_local_y:int) { super(i_local_x, i_local_y); return; } public override function getParam_5(i_dest_w:int,i_dest_h:int,x1:Number,y1:Number,x2:Number,y2:Number,x3:Number,y3:Number,x4:Number,y4:Number,o_param:Vector.):Boolean { var ltx:Number = this._local_x; var lty:Number = this._local_y; var rbx:Number = ltx + i_dest_w; var rby:Number = lty + i_dest_h; var det_1:Number; var a13:Number, a14:Number, a23:Number, a24:Number, a33:Number, a34:Number, a43:Number, a44:Number; var b11:Number, b12:Number, b13:Number, b14:Number, b21:Number, b22:Number, b23:Number, b24:Number, b31:Number, b32:Number, b33:Number, b34:Number, b41:Number, b42:Number, b43:Number, b44:Number; var t1:Number, t2:Number, t3:Number, t4:Number, t5:Number, t6:Number; var v1:Number, v2:Number, v3:Number, v4:Number; var kx0:Number, kx1:Number, kx2:Number, kx3:Number, kx4:Number, kx5:Number, kx6:Number, kx7:Number; var ky0:Number, ky1:Number, ky2:Number, ky3:Number, ky4:Number, ky5:Number, ky6:Number, ky7:Number; { a13 = -ltx * x1; a14 = -lty * x1; a23 = -rbx * x2; a24 = -lty * x2; a33 = -rbx * x3; a34 = -rby * x3; a43 = -ltx * x4; a44 = -rby * x4; t1 = a33 * a44 - a34 * a43; t4 = a34 * ltx - rbx * a44; t5 = rbx * a43 - a33 * ltx; t2 = rby * (a34 - a44); t3 = rby * (a43 - a33); t6 = rby * (rbx - ltx); b21 = -a23 * t4 - a24 * t5 - rbx * t1; b11 = (a23 * t2 + a24 * t3) + lty * t1; b31 = (a24 * t6 - rbx * t2) + lty * t4; b41 = (-rbx * t3 - a23 * t6) + lty * t5; t1 = a43 * a14 - a44 * a13; t2 = a44 * lty - rby * a14; t3 = rby * a13 - a43 * lty; t4 = ltx * (a44 - a14); t5 = ltx * (a13 - a43); t6 = ltx * (lty - rby); b12 = -rby * t1 - a33 * t2 - a34 * t3; b22 = (a33 * t4 + a34 * t5) + rbx * t1; b32 = (-a34 * t6 - rby * t4) + rbx * t2; b42 = (-rby * t5 + a33 * t6) + rbx * t3; t1 = a13 * a24 - a14 * a23; t4 = a14 * rbx - ltx * a24; t5 = ltx * a23 - a13 * rbx; t2 = lty * (a14 - a24); t3 = lty * (a23 - a13); t6 = lty * (ltx - rbx); b23 = -a43 * t4 - a44 * t5 - ltx * t1; b13 = (a43 * t2 + a44 * t3) + rby * t1; b33 = (a44 * t6 - ltx * t2) + rby * t4; b43 = (-ltx * t3 - a43 * t6) + rby * t5; t1 = a23 * a34 - a24 * a33; t2 = a24 * rby - lty * a34; t3 = lty * a33 - a23 * rby; t4 = rbx * (a24 - a34); t5 = rbx * (a33 - a23); t6 = rbx * (rby - lty); b14 = -lty * t1 - a13 * t2 - a14 * t3; b24 = a13 * t4 + a14 * t5 + ltx * t1; b34 = -a14 * t6 - lty * t4 + ltx * t2; b44 = -lty * t5 + a13 * t6 + ltx * t3; det_1 = (ltx * (b11 + b14) + rbx * (b12 + b13)); if (det_1 == 0) { det_1=0.0001; //System.out.println("Could not get inverse matrix(1)."); //return false; } det_1 = 1 / det_1; kx0 = (b11 * x1 + b12 * x2 + b13 * x3 + b14 * x4) * det_1; kx1 = (b11 + b12 + b13 + b14) * det_1; kx2 = (b21 * x1 + b22 * x2 + b23 * x3 + b24 * x4) * det_1; kx3 = (b21 + b22 + b23 + b24) * det_1; kx4 = (b31 * x1 + b32 * x2 + b33 * x3 + b34 * x4) * det_1; kx5 = (b31 + b32 + b33 + b34) * det_1; kx6 = (b41 * x1 + b42 * x2 + b43 * x3 + b44 * x4) * det_1; kx7 = (b41 + b42 + b43 + b44) * det_1; } { a13 = -ltx * y1; a14 = -lty * y1; a23 = -rbx * y2; a24 = -lty * y2; a33 = -rbx * y3; a34 = -rby * y3; a43 = -ltx * y4; a44 = -rby * y4; t1 = a33 * a44 - a34 * a43; t4 = a34 * ltx - rbx * a44; t5 = rbx * a43 - a33 * ltx; t2 = rby * (a34 - a44); t3 = rby * (a43 - a33); t6 = rby * (rbx - ltx); b21 = -a23 * t4 - a24 * t5 - rbx * t1; b11 = (a23 * t2 + a24 * t3) + lty * t1; b31 = (a24 * t6 - rbx * t2) + lty * t4; b41 = (-rbx * t3 - a23 * t6) + lty * t5; t1 = a43 * a14 - a44 * a13; t2 = a44 * lty - rby * a14; t3 = rby * a13 - a43 * lty; t4 = ltx * (a44 - a14); t5 = ltx * (a13 - a43); t6 = ltx * (lty - rby); b12 = -rby * t1 - a33 * t2 - a34 * t3; b22 = (a33 * t4 + a34 * t5) + rbx * t1; b32 = (-a34 * t6 - rby * t4) + rbx * t2; b42 = (-rby * t5 + a33 * t6) + rbx * t3; t1 = a13 * a24 - a14 * a23; t4 = a14 * rbx - ltx * a24; t5 = ltx * a23 - a13 * rbx; t2 = lty * (a14 - a24); t3 = lty * (a23 - a13); t6 = lty * (ltx - rbx); b23 = -a43 * t4 - a44 * t5 - ltx * t1; b13 = (a43 * t2 + a44 * t3) + rby * t1; b33 = (a44 * t6 - ltx * t2) + rby * t4; b43 = (-ltx * t3 - a43 * t6) + rby * t5; t1 = a23 * a34 - a24 * a33; t2 = a24 * rby - lty * a34; t3 = lty * a33 - a23 * rby; t4 = rbx * (a24 - a34); t5 = rbx * (a33 - a23); t6 = rbx * (rby - lty); b14 = -lty * t1 - a13 * t2 - a14 * t3; b24 = a13 * t4 + a14 * t5 + ltx * t1; b34 = -a14 * t6 - lty * t4 + ltx * t2; b44 = -lty * t5 + a13 * t6 + ltx * t3; det_1 = (ltx * (b11 + b14) + rbx * (b12 + b13)); if (det_1 == 0) { det_1=0.0001; //System.out.println("Could not get inverse matrix(2)."); //return false; } det_1 = 1 / det_1; ky0 = (b11 * y1 + b12 * y2 + b13 * y3 + b14 * y4) * det_1; ky1 = (b11 + b12 + b13 + b14) * det_1; ky2 = (b21 * y1 + b22 * y2 + b23 * y3 + b24 * y4) * det_1; ky3 = (b21 + b22 + b23 + b24) * det_1; ky4 = (b31 * y1 + b32 * y2 + b33 * y3 + b34 * y4) * det_1; ky5 = (b31 + b32 + b33 + b34) * det_1; ky6 = (b41 * y1 + b42 * y2 + b43 * y3 + b44 * y4) * det_1; ky7 = (b41 + b42 + b43 + b44) * det_1; } det_1 = kx5 * (-ky7) - (-ky5) * kx7; if (det_1 == 0) { det_1=0.0001; //System.out.println("Could not get inverse matrix(3)."); //return false; } det_1 = 1 / det_1; var C:Number, F:Number; o_param[2] = C = (-ky7 * det_1) * (kx4 - ky4) + (ky5 * det_1) * (kx6 - ky6); // C o_param[5] = F = (-kx7 * det_1) * (kx4 - ky4) + (kx5 * det_1) * (kx6 - ky6); // F o_param[6] = kx4 - C * kx5; o_param[7] = kx6 - C * kx7; o_param[0] = kx0 - C * kx1; o_param[1] = kx2 - C * kx3; o_param[3] = ky0 - F * ky1; o_param[4] = ky2 - F * ky3; return true; } } }