Tôi đang cố sử dụng Zhang-Suen thinning algorithm. Tôi đã cố gắng thực hiện nó trong Java. Nhưng vấn đề là nó tìm thấy tôi cạnh không phải là một chiều rộng một pixel. Lần đầu tiên tôi đang sử dụng thuật toán này và tôi không biết những gì là sai với logic của tôi.Thực hiện thuật toán mỏng Zhang-Suen không hoạt động như mong đợi
Những gì tôi muốn đạt được là:
gì tôi có thể đạt được là:
public void thinStepI(){
delList.clear();
neighbor = 0;
connectivity = 0;
for(int i=4;i<width-4;i++)
for(int j=4;j<height-4;j++){
p = pixelList[i][j];
if (p == 1){
p1 = pixelList[i-1][j];
p2 = pixelList[i-1][j+1];
p3 = pixelList[i][j+1];
p4 = pixelList[i+1][j+1];
p5 = pixelList[i+1][j];
p6 = pixelList[i+1][j-1];
p7 = pixelList[i][j-1];
p8 = pixelList[i-1][j-1];
neighbor = p1 + p2 + p3 + p4 + p5 + p6 + p7 + p8;
if (p1 == 0 && p2 == 1)
connectivity ++;
if (p2 == 0 && p3 == 1)
connectivity ++;
if (p3 == 0 && p4 == 1)
connectivity ++;
if (p4 == 0 && p5 == 1)
connectivity ++;
if (p5 == 0 && p6 == 1)
connectivity ++;
if (p6 == 0 && p7 == 1)
connectivity ++;
if (p7 == 0 && p8 == 1)
connectivity ++;
if (p8 == 0 && p1 == 1)
connectivity ++;
if (connectivity == 1 && (neighbor >= 2 && neighbor <= 6) &&
(p1 * p3 * p5 == 0) && (p3 * p5 * p7 == 0)){
delList.add(i);
delList.add(j);
}
}
}
int length = delList.size();
if (length != 0){
for(int i =0; i < (length - 1); i+=2){
pixelList[delList.get(i)][delList.get(i+1)] = 0;
System.out.println("oldu");
}
thinStepI();
}
}
public void thinStepII(){
delList.clear();
neighbor = 0;
connectivity = 0;
for(int i=4;i<width-4;i++)
for(int j=4;j<height-4;j++){
if (pixelList[i][j] == 1){
p = pixelList[i][j]; // ** Origin Pixel **
p1 = pixelList[i-1][j];
p2 = pixelList[i-1][j+1];
p3 = pixelList[i][j+1];
p4 = pixelList[i+1][j+1];
p5 = pixelList[i+1][j];
p6 = pixelList[i+1][j-1];
p7 = pixelList[i][j-1];
p8 = pixelList[i-1][j-1];
neighbor = p1 + p2 + p3 + p4 + p5 + p6 + p7 + p8;
if (p1 == 0 && p2 == 1)
connectivity ++;
if (p2 == 0 && p3 == 1)
connectivity ++;
if (p3 == 0 && p4 == 1)
connectivity ++;
if (p4 == 0 && p5 == 1)
connectivity ++;
if (p5 == 0 && p6 == 1)
connectivity ++;
if (p6 == 0 && p7 == 1)
connectivity ++;
if (p7 == 0 && p8 == 1)
connectivity ++;
if (p8 == 0 && p1 == 1)
connectivity ++;
if (connectivity == 1 && (neighbor >= 2 && neighbor <= 6) &&
(p1 * p3 * p7 == 0) && (p1 * p5 * p7 == 0)){
delList.add(i);
delList.add(j);
}
}
}
int length = delList.size();
if (length != 0){
for(int i =0; i < (length - 1); i+=2){
pixelList[delList.get(i)][delList.get(i+1)] = 0;
System.out.println("oldu2");
}
thinStepII();
}
}
đâu là lỗi trong logic của tôi đó gây ra tôi để có được kết quả không chính xác?
Câu hỏi của bạn là gì? – tskuzzy
Như tôi đã nghiên cứu, nó sẽ làm mỏng các ký tự thành một dòng. Ý tôi là, mỗi ký tự phải bao gồm một đường rộng như trong hình thứ hai. Nhưng nó đang tìm kiếm như là khung của các chữ cái. Tôi chỉ cần như trong hình ảnh thứ hai. – Ecrin