chain code for line

3 views (last 30 days)
majed majed
majed majed on 5 Nov 2015
Commented: majed majed on 7 Nov 2015
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 .

Accepted Answer

Walter Roberson
Walter Roberson on 6 Nov 2015
  1 Comment
majed majed
majed majed on 7 Nov 2015
Thank you to your answer, I have traied it , but I didn't get the gall.

Sign in to comment.

More Answers (1)

Guillaume
Guillaume on 5 Nov 2015
Edited: Guillaume on 5 Nov 2015
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 Comment
majed majed
majed majed on 6 Nov 2015
Edited: majed majed on 6 Nov 2015
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

Sign in to comment.

Categories

Find more on Image Processing Toolbox in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!