利用Matlab从图片中获取凸多边形的内角角度

利用matlab中的ginput函数获取坐标,求该三点确定的三角形的边长,然后利用三边长求角度的公式

cosA=\frac{b^2+c^2-a^2}{2bc}

求出夹角,将角度在坐标后面标出来。想获取每个内角的角度的话可以对每一个角重复一次操作。

标注效果如下图:

代码如下(将imread('五边形.png')中的名称改成绝对地址或者改成matla路径下的相对地址就可运行。)

close all;
clear; clc;
pic=imread('五边形.png');

I=imshow(pic);%显示图片

loc_points=zeros(3,2);%设一个三行两列的全零矩阵

%[x,y]=getpts;
for i=1:1:3%循环三次,分别获取三个点的坐标
    
hold on;  
[x, y]=ginput(1);

hold on;
plot(x,y,'r.')%将点在其中标记出来

loc_points(i,1) = x;
loc_points(i,2) = y;%将坐标存入数组

str=['  X:' num2str(x') ', Y:' num2str(y')];
text(x,y,cellstr(str))

end
%计算三边长
a=sqrt((loc_points(1,1)-loc_points(2,1))^2+(loc_points(1,2)-loc_points(2,2))^2)
b=sqrt((loc_points(2,1)-loc_points(3,1))^2+(loc_points(2,2)-loc_points(3,2))^2)
c=sqrt((loc_points(1,1)-loc_points(3,1))^2+(loc_points(1,2)-loc_points(3,2))^2)
%求夹角的余弦值
cosC=(b^2+a^2-c^2)/(2*b*a)
sigma3=acos(cosC)/pi*180
%将角度标在点坐标的后面
str=[', \alpha:' num2str(sigma3'),'\circ'];
text(loc_points(2,1)+100,loc_points(2,2),cellstr(str))


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值