chain code for line

조회 수: 1 (최근 30일)
majed majed
majed majed 2015년 11월 5일
댓글: majed majed 2015년 11월 7일
here is my question : in this image which I have attached , starting from (x,y) or (s,t)how can I write the chain code for the line ? what is proper idea to write its code ? a lot of thank for everyone help me or try to help .

채택된 답변

Walter Roberson
Walter Roberson 2015년 11월 6일
  댓글 수: 1
majed majed
majed majed 2015년 11월 7일
Thank you to your answer, I have traied it , but I didn't get the gall.

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

Guillaume
Guillaume 2015년 11월 5일
편집: Guillaume 2015년 11월 5일
I've no idea what a chain code is, but if you're wanting to trace the path from (s,t) to (I,J) isn't it simply finding which of the eight neighbouring pixel is black, excluding pixels you've already been through.
currentrow = s;
currentcol = t;
path = [currentrow currentcol]
while currentrow ~= I && currentrow ~= J
[neighbours(:, 1), neighbours(:, 2)] = find(img(currentrow-1:currentrow+1, currentcol-1:currentcol+1) & [1 1 1;1 0 1;1 1 1])); %ignoring edge issues here
notvisited = ~ismember(neighbours, path, 'rows');
path = [path; neighbours(notvisited)]; %assumes there's only ever one non-visited neighbour
currentrow = neighbours(notvisited, 1);
currentcol = neighbours(notvisited, 2);
end
  댓글 수: 1
majed majed
majed majed 2015년 11월 6일
편집: majed majed 2015년 11월 6일
Thank you a lot , in my question if I start from any edge ,I don't know where is the other edge , so when I find the starting point (one of the edges) ,I need to extract the angle between current pixel and next pixel according to freeman chaincode edea ,suppose that the pixels inside line has just tow neighbors. that's it exactly what I want, thanks

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Image Processing Toolbox에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by