这个过去用就写过,这次正好有人问这个算法,所以在这里又把C代码改为了matlab了。
霍夫变换是把原图像中的直线上的每一个点转换到参数空间对应的曲线上,由于每一个点对应一条曲线,因此在参数空间中所有曲线会相交到一个点,形成一个最值。因此原图寻找直线斜率的问题就变成了参数空间寻找最值的问题了。
代码如下:
clear all; close all; clc; %% %以下只是做一个带直线的图像而已 r=300; jiaodu=30; %更改这个值测试,90度270度时不管用 jiaodu1=mod(jiaodu,360); flag=0; if jiaodu1>=0 && jiaodu1<90 jiaodu1=jiaodu1; flag=1; end if jiaodu1>=90 && jiaodu1<180 jiaodu1=180-jiaodu1; flag=2