📄 nyarqrcodedetector.java
字号:
//配列作成
this._dist_factor_ref.observ2IdealBatch(i_xcoord, i_ycoord, st, n,this._xpos,this._ypos);
//主成分分析する。
this._pca.pca(this._xpos,this._ypos,n,evec, ev,mean);
final NyARLinear l_line_i = o_line[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);// line[i][2] = -(line[i][0]*mean->v[0] + line[i][1]*mean->v[1]);
}
for (int i = 0; i < 4; i++) {
final NyARLinear l_line_i = o_line[i];
final NyARLinear l_line_2 = o_line[(i + 3) % 4];
final double w1 = l_line_2.run * l_line_i.rise - l_line_i.run * l_line_2.rise;
if (w1 == 0.0) {
return false;
}
// 頂点インデクスから頂点座標を得て保存
o_imvertex[i].x = i_xcoord[i_mkvertex[i]];
o_imvertex[i].y = i_ycoord[i_mkvertex[i]];
}
return true;
}
/**
* 辺からの対角線が最長になる点を対角線候補として返す。
*
* @param i_xcoord
* @param i_ycoord
* @param i_coord_num
* @return
*/
private int scanVertex(int[] i_xcoord, int[] i_ycoord, int i_coord_num)
{
final int sx = i_xcoord[0];
final int sy = i_ycoord[0];
int d = 0;
int w, x, y;
int ret = 0;
for (int i = 1; i < i_coord_num; i++) {
x = i_xcoord[i] - sx;
y = i_ycoord[i] - sy;
w = x * x + y * y;
if (w > d) {
d = w;
ret = i;
}
// ここでうまく終了条件入れられないかな。
}
return ret;
}
private final NyARVertexCounter __getSquareVertex_wv1 = new NyARVertexCounter();
private final 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)
{
final NyARVertexCounter wv1 = this.__getSquareVertex_wv1;
final NyARVertexCounter wv2 = this.__getSquareVertex_wv2;
final int end_of_coord = i_vertex1_index + i_coord_num - 1;
final int sx = i_x_coord[i_vertex1_index];// sx = marker_info2->x_coord[0];
final 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++)
// {
final 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;
}
}
final 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;
}
/**
* QRコードのシンボル特徴を持つラベルであるかを調べる
* @param buf
* @param index_table
* @param i_label
* @return
*/
private boolean hasQrEdgeFeature(int buf[][], int[] index_table, NyARLabelingLabel i_label)
{
int tx, bx;
int w;
int i_label_id = i_label.id;
int[] limage_j;
final int clip_l = i_label.clip_l;
final int clip_b = i_label.clip_b;
final int clip_r = i_label.clip_r;
final int clip_t = i_label.clip_t;
tx = bx = 0;
// 上接点(→)
limage_j = buf[clip_t];
for (int i = clip_l; i <= clip_r; i++) {// for( i = clip[0]; i <=clip[1]; i++, p1++ ) {
w = limage_j[i];
if (w > 0 && index_table[w - 1] == i_label_id) {
tx = i;
break;
}
}
// 下接点(←)
limage_j = buf[clip_b];
for (int i = clip_r; i >= clip_l; i--) {// for( i = clip[0]; i <=clip[1]; i++, p1++ ) {
w = limage_j[i];
if (w > 0 && index_table[w - 1] == i_label_id) {
bx = i;
break;
}
}
final int cx = (clip_l + clip_r) / 2;
final int cy = (clip_t + clip_b) / 2;
// 横断チェック(中心から線を引いて、010になるかしらべる)
if (!checkDiagonalLine(buf, cx, cy, bx, clip_b)) {
return false;
}
if (!checkDiagonalLine(buf, tx, clip_t, cx, cy)) {
return false;
}
return true;
}
/**
* シンボルのパターン特徴を調べる関数
* 対角線の一部が010になってるか調べる。
*
* @param buf
* @param i_px1
* @param i_py1
* @param i_px2
* @param i_py2
* @return
*/
private boolean checkDiagonalLine(int[][] buf, int i_px1, int i_py1, int i_px2, int i_py2)
{
int sub_y = i_py2 - i_py1;
int sub_x = i_px2 - i_px1;
// 黒
int i = 0;
for (; i < sub_y; i++) {
int yp = i_py1 + i;
int xp = i_px1 + i * sub_x / sub_y;
if (buf[yp][xp] == 0 && buf[yp][xp-1] == 0 && buf[yp][xp+1] == 0) {
break;
}
}
if (i == sub_y) {
return false;
}
// 白
for (; i < sub_y; i++) {
int yp = i_py1 + i;
int xp = i_px1 + i * sub_x / sub_y;
if (buf[yp][xp] != 0 && buf[yp][xp-1] != 0 && buf[yp][xp+1] != 0) {
break;
}
}
if (i == sub_y) {
return false;
}
// 黒
for (; i < sub_y; i++) {
int yp = i_py1 + i;
int xp = i_px1 + i * sub_x / sub_y;
if (buf[yp][xp] == 0 && buf[yp][xp-1] == 0 && buf[yp][xp+1] == 0) {
break;
}
}
if (i != sub_y) {
return false;
}
// 端まで到達したらOK
return true;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -