性格悪い人が優勝

輪郭線追跡をしてそのコードを出力させるプログラムを書いたのですが、trace関数のwhileの中が全く作動していないみたいで、どのようにすれば実行できるのかわかる方教えて頂きたいです。
エラーは出ずに、findStartPt関数の最初の点のみ出力されてプログラムが終了してしまいます。

#include <stdio.h>
#include <stdlib.h>
#define NN 1600000
#define COL_BLACK 0
#define COL_WHITE 255
void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num);
void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj);
int main(int argc, char *argv[])
{
int im,jm;
char fname[100];
unsigned char image[NN];
int i,j;
int th;
int col;
int starti, startj;
int num=0;
int fcode[NN];

printf("元の画像ファイル名を入れてください: \n");
scanf("%s",fname);
read_pnm(fname, &im, &jm, &col, image);

findStartPt(image,im,jm,&starti,&startj);
printf("%d %d\n", starti, startj);
num=1;
trace(image,im,jm,starti, startj, fcode, &num);
}
typedef struct dir_t{
//direction//進む方向
int x, y;
}Dir;
const Dir dir[] = {
{1, 0}, {1, 1}, {-1, 1}, {-1, 1}, {-1, 0},{-1, -1}, {0, -1}, {1, -1},
};
const int dirs = sizeof(dir)/sizeof(dir[0]);
void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num)
{
int i;
int x, y;
*num = 0;
while(x<=im && y<=jm && image[y*im + x] == COL_BLACK){
for(i=0; i<dirs; i++){
if(image[(y+dir[i].y)*im + (x+dir[i].x)] == COL_BLACK){
fcode[(y+dir[i].y)*im+(x+dir[i].x)] = i;
printf("%d\n",fcode[(y+dir[i].y)*im+(x+dir[i].x)]);
x += dir[i].x;
y += dir[i].y;
*num++;
break;
}
}
}
}

void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj)
{
int i, j;
int dist;
int dmin=im*im+jm*jm;
// find start point
for (j=0;j<jm;++j) {
for (i=0;i<im;++i) {
if (image[i+j*im]==255) {
dist=i*i+j*j;
if (dist<dmin) {
*starti=i;
*startj=j;
dmin=dist;
}
}
}
}
}
void read_pnm(char filename[],int *im,int *jm, int *col, unsigned char image[])
{
int i,j;
FILE *fp;
char buf[10000];

if((fp=fopen(filename,"rb"))==NULL)
{
printf("file %s can not open ",filename);
exit(0);
}
check_pnm(buf,fp,im,jm,col);
fread(image,sizeof(unsigned char),(*im)*(*jm)*(*col),fp);
fclose(fp);
}

A 回答 (1件)

findStartPt で見付けた starti, startj ってどういう条件を満たす? そしてそのとき trace はどのように動く?



そもそもあなたのいう「輪郭線追跡」とやらの「輪郭線」ってなんなの?
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!