Help with line detection in image!
6 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
I want to get rid of all lines(excluding the text) from my image: https://www.dropbox.com/s/xu8lngoesii75rl/test2.tiff. Below is the code I'm using;
I = imread('1b.bmp');
%rotI = imrotate(I,33,'crop');
rotI=I;
%fig1 = imshow(rotI);
%se = strel('line',12,90);
%BW = imdilate(BW,se);
BW = bwmorph(I,'thicken');
%BW = edge(BW,'canny');
%BW1 = imrotate(BW,90,'crop');
figure, imshow(BW);
%BW=rotI;
[H,theta,rho] = hough(BW,'Theta',-90:0.5:89.5);
figure, imshow(imadjust(mat2gray(H)),[],'XData',theta,'YData',rho,...
'InitialMagnification','fit');
xlabel('\theta (degrees)'), ylabel('\rho');
axis on, axis normal, hold on;
colormap(hot)
P = houghpeaks(H,8,'threshold',ceil(0.3*max(H(:))));
x = theta(P(:,2));
y = rho(P(:,1));
plot(x,y,'s','color','w');
lines = houghlines(BW,theta,rho,P,'FillGap',5,'MinLength',5);
figure, imshow(BW), hold on
max_len = 0;
for k = 1:length(lines)
xy = [lines(k).point1; lines(k).point2];
plot(xy(:,1),xy(:,2),'LineWidth',2,'Color','green');
% Plot beginnings and ends of lines
%plot(xy(1,1),xy(1,2),'x','LineWidth',2,'Color','yellow');
% plot(xy(2,1),xy(2,2),'x','LineWidth',2,'Color','red');
% Determine the endpoints of the longest line segment
end
% highlight the longest line segment
%plot(xy_long(:,1),xy_long(:,2),'LineWidth',2,'Color','red');
The code can detect most of the lines but not all. I need help with the code so that it can detect all the lines, and remove them leaving only the text. You can also suggest a better way of doing it if you think there is. Please help!
0 Kommentare
Antworten (0)
Siehe auch
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!