annotation函数使用的数据为归一化数据,及将整个图像窗口看做1*1的大小,所以需要对所有数据进行归一化处理(包括坐标轴和函数图像坐标)
%%annotation函数学习 画切线(使用归一化的数据绘制)
clear
clc
syms x y y1 %建立符号变量来指代符号方程
y=x^3+2*x;
y1=diff(y,x); %对y求关于x的导数
x1=-5:0.5:5; %定义x轴范围
y=double(subs(y,x,x1)); %subs(s,old,new) 符号变量的赋值
y1=double(subs(y1,x,x1));
sita=atan(y1); %求每个点的actan值 即角度
tx=y1.*cos(sita);
ty=y1.*sin(sita);
p=plot(x1,y);
axis([-5 10 -150 200]); %坐标轴进行扩大处理,因为切线可能超出坐标轴范围,程序报错
hold on
xlim=get(p.Parent,'XLim'); %图像的父类就是它的坐标轴 得到x轴的坐标范围
ylim=get(p.Parent,'YLim');
po=get(p.Parent,'Position'); %得到坐标系相对于窗口的位置信息
[~,px]=mapminmax(xlim,po(1),po(1)+po(3)); %对x轴数据进行归一化处理 px是一个结构体,存储的是如何将x坐标进行归一化处理,可以使对图像的归一化处理和坐标轴同一处理方式
[~,py]=mapminmax(ylim,po(2),po(2)+po(4));
xx1=mapminmax('apply',x1,px); %对图像进行和坐标轴一样的归一化
yy1=mapminmax('apply',y,py);
ttx=mapminmax('apply',x1+tx,px);%切线为一矢量,所以有起点有终点
tty=mapminmax('apply',y+ty,py);
for i=1:length(x1)
ann=annotation('arrow',[xx1(i),ttx(i)],[yy1(i),tty(i)]);
end