⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nyarsquaredetector_quad.java

📁 java 版的 ARToolkit
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
                d = w;
                ret = i;
            }
            // ここでうまく終了条件入れられないかな。
        }
        return ret;
    }

    private NyARVertexCounter __getSquareVertex_wv1 = new NyARVertexCounter();

    private NyARVertexCounter __getSquareVertex_wv2 = new NyARVertexCounter();

    /**
     * static int arDetectMarker2_check_square( int area, ARMarkerInfo2 *marker_info2, double factor ) 関数の代替関数 OPTIMIZED STEP [450->415] o_squareに頂点情報をセットします。
     * 
     * @param i_x_coord
     * @param i_y_coord
     * @param i_vertex1_index
     * @param i_coord_num
     * @param i_area
     * @param o_vertex
     * 要素数はint[4]である事
     * @return
     */
    private boolean getSquareVertex(int[] i_x_coord, int[] i_y_coord, int i_vertex1_index, int i_coord_num, int i_area, int[] o_vertex)
    {
        NyARVertexCounter wv1 = this.__getSquareVertex_wv1;
        NyARVertexCounter wv2 = this.__getSquareVertex_wv2;
        int end_of_coord = i_vertex1_index + i_coord_num - 1;
        int sx = i_x_coord[i_vertex1_index];// sx = marker_info2->x_coord[0];
        int sy = i_y_coord[i_vertex1_index];// sy = marker_info2->y_coord[0];
        int dmax = 0;
        int v1 = i_vertex1_index;
        for (int i = 1 + i_vertex1_index; i < end_of_coord; i++)
        {// for(i=1;i<marker_info2->coord_num-1;i++)
            // {
            int d = (i_x_coord[i] - sx) * (i_x_coord[i] - sx) + (i_y_coord[i] - sy) * (i_y_coord[i] - sy);
            if (d > dmax)
            {
                dmax = d;
                v1 = i;
            }
        }
        double thresh = (i_area / 0.75) * 0.01 * VERTEX_FACTOR;

        o_vertex[0] = i_vertex1_index;

        if (!wv1.getVertex(i_x_coord, i_y_coord, i_vertex1_index, v1, thresh))
        { // if(get_vertex(marker_info2->x_coord,marker_info2->y_coord,0,v1,thresh,wv1,&wvnum1)<
            // 0 ) {
            return false;
        }
        if (!wv2.getVertex(i_x_coord, i_y_coord, v1, end_of_coord, thresh))
        {// if(get_vertex(marker_info2->x_coord,marker_info2->y_coord,v1,marker_info2->coord_num-1,thresh,wv2,&wvnum2)
            // < 0) {
            return false;
        }

        int v2;
        if (wv1.number_of_vertex == 1 && wv2.number_of_vertex == 1)
        {// if(wvnum1 == 1 && wvnum2== 1) {
            o_vertex[1] = wv1.vertex[0];
            o_vertex[2] = v1;
            o_vertex[3] = wv2.vertex[0];
        }
        else if (wv1.number_of_vertex > 1 && wv2.number_of_vertex == 0)
        {// }else if( wvnum1 > 1 && wvnum2== 0) {
            //頂点位置を、起点から対角点の間の1/2にあると予想して、検索する。
            v2 = (v1 - i_vertex1_index) / 2 + i_vertex1_index;
            if (!wv1.getVertex(i_x_coord, i_y_coord, i_vertex1_index, v2, thresh))
            {
                return false;
            }
            if (!wv2.getVertex(i_x_coord, i_y_coord, v2, v1, thresh))
            {
                return false;
            }
            if (wv1.number_of_vertex == 1 && wv2.number_of_vertex == 1)
            {
                o_vertex[1] = wv1.vertex[0];
                o_vertex[2] = wv2.vertex[0];
                o_vertex[3] = v1;
            }
            else
            {
                return false;
            }
        }
        else if (wv1.number_of_vertex == 0 && wv2.number_of_vertex > 1)
        {
            //v2 = (v1-i_vertex1_index+ end_of_coord-i_vertex1_index) / 2+i_vertex1_index;
            v2 = (v1 + end_of_coord) / 2;

            if (!wv1.getVertex(i_x_coord, i_y_coord, v1, v2, thresh))
            {
                return false;
            }
            if (!wv2.getVertex(i_x_coord, i_y_coord, v2, end_of_coord, thresh))
            {
                return false;
            }
            if (wv1.number_of_vertex == 1 && wv2.number_of_vertex == 1)
            {
                o_vertex[1] = v1;
                o_vertex[2] = wv1.vertex[0];
                o_vertex[3] = wv2.vertex[0];
            }
            else
            {
                return false;
            }
        }
        else
        {
            return false;
        }
        o_vertex[4] = end_of_coord;
        return true;
    }
    private int[] _xpos;
    private int[] _ypos;
    private NyARFixedFloatPca2d _pca;
    private NyARI64Matrix22 __getSquareLine_evec = new NyARI64Matrix22();
    private NyARI64Point2d __getSquareLine_mean = new NyARI64Point2d();
    private NyARI64Point2d __getSquareLine_ev = new NyARI64Point2d();
    private NyARI64Linear[] __getSquareLine_i64liner = NyARI64Linear.createArray(4);
    /**
     * arGetLine(int x_coord[], int y_coord[], int coord_num,int vertex[], double line[4][3], double v[4][2]) arGetLine2(int x_coord[], int y_coord[], int
     * coord_num,int vertex[], double line[4][3], double v[4][2], double *dist_factor) の2関数の合成品です。 マーカーのvertex,lineを計算して、結果をo_squareに保管します。
     * Optimize:STEP[424->391]
     * 
     * @param i_cparam
     * @return
     * @throws NyARException
     */
    private boolean getSquareLine(int[] i_mkvertex, int[] i_xcoord, int[] i_ycoord, NyARSquare o_square) throws NyARException
    {
        NyARLinear[] l_line = o_square.line;
        NyARI64Matrix22 evec = this.__getSquareLine_evec;
        NyARI64Point2d mean = this.__getSquareLine_mean;
        NyARI64Point2d ev = this.__getSquareLine_ev;
        NyARI64Linear[] i64liner = this.__getSquareLine_i64liner;


        for (int i = 0; i < 4; i++)
        {
            double w1 = (double)(i_mkvertex[i + 1] - i_mkvertex[i] + 1) * 0.05 + 0.5;
            int st = (int)(i_mkvertex[i] + w1);
            int ed = (int)(i_mkvertex[i + 1] - w1);
            int n = ed - st + 1;
            if (n < 2)
            {
                // nが2以下でmatrix.PCAを計算することはできないので、エラー
                return false;
            }
            //配列作成
            n = this._dist_factor.observ2IdealSampling(i_xcoord, i_ycoord, st, n, this._xpos, this._ypos, PCA_LENGTH);

            //主成分分析する。
            this._pca.pcaF16(this._xpos, this._ypos, n, evec, ev, mean);
            NyARI64Linear l_line_i = i64liner[i];
            l_line_i.run = evec.m01;// line[i][0] = evec->m[1];
            l_line_i.rise = -evec.m00;// line[i][1] = -evec->m[0];
            l_line_i.intercept = -((l_line_i.run * mean.x + l_line_i.rise * mean.y) >> 16);// line[i][2] = -(line[i][0]*mean->v[0] + line[i][1]*mean->v[1]);
        }

        NyARDoublePoint2d[] l_sqvertex = o_square.sqvertex;
        NyARIntPoint[] l_imvertex = o_square.imvertex;
        for (int i = 0; i < 4; i++)
        {
            NyARI64Linear l_line_i = i64liner[i];
            NyARI64Linear l_line_2 = i64liner[(i + 3) % 4];
            long w1 = (l_line_2.run * l_line_i.rise - l_line_i.run * l_line_2.rise) >> 16;
            if (w1 == 0)
            {
                return false;
            }
            l_sqvertex[i].x = (double)((l_line_2.rise * l_line_i.intercept - l_line_i.rise * l_line_2.intercept) / w1) *2/ 65536.0;
            l_sqvertex[i].y = (double)((l_line_i.run * l_line_2.intercept - l_line_2.run * l_line_i.intercept) / w1) *2/ 65536.0;
            // 頂点インデクスから頂点座標を得て保存
            l_imvertex[i].x = i_xcoord[i_mkvertex[i]]*2;
            l_imvertex[i].y = i_ycoord[i_mkvertex[i]]*2;
            l_line[i].run = (double)l_line_i.run / 65536.0;
            l_line[i].rise = (double)l_line_i.rise / 65536.0;
            l_line[i].intercept = (double)l_line_i.intercept*2 / 65536.0;
        }
        return true;
    }
}


/**
 * ラベル同士の重なり(内包関係)を調べるクラスです。 
 * ラベルリストに内包するラベルを蓄積し、それにターゲットのラベルが内包されているか を確認します。
 */
class OverlapChecker
{
    private NyARLabelingLabel[] _labels = new NyARLabelingLabel[32];

    private int _length;

    /**
     * 最大i_max_label個のラベルを蓄積できるようにオブジェクトをリセットする
     * 
     * @param i_max_label
     */
    public void reset(int i_max_label)
    {
        if (i_max_label > this._labels.length)
        {
            this._labels = new NyARLabelingLabel[i_max_label];
        }
        this._length = 0;
    }

    /**
     * チェック対象のラベルを追加する。
     * 
     * @param i_label_ref
     */
    public void push(NyARLabelingLabel i_label_ref)
    {
        this._labels[this._length] = i_label_ref;
        this._length++;
    }

    /**
     * 現在リストにあるラベルと重なっているかを返す。
     * 
     * @param i_label
     * @return 何れかのラベルの内側にあるならばfalse,独立したラベルである可能性が高ければtrueです.
     */
    public boolean check(NyARLabelingLabel i_label)
    {
        // 重なり処理かな?
        NyARLabelingLabel[] label_pt = this._labels;
        int px1 = (int)i_label.pos_x;
        int py1 = (int)i_label.pos_y;
        for (int i = this._length - 1; i >= 0; i--)
        {
            int px2 = (int)label_pt[i].pos_x;
            int py2 = (int)label_pt[i].pos_y;
            int d = (px1 - px2) * (px1 - px2) + (py1 - py2) * (py1 - py2);
            if (d < label_pt[i].area / 4)
            {
                // 対象外
                return false;
            }
        }
        // 対象
        return true;
    }
}


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -