找回密码
 注册
关于网站域名变更的通知
查看: 1178|回复: 1
打印 上一主题 下一主题

用Matlab绘制任意两点之间带箭头的直线

[复制链接]
  • TA的每日心情

    2019-11-20 15:22
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2020-3-9 13:29 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    工作环境
    / p# e6 v2 o; _/ A. x) L
    ( D/ w( \( G# J$ ?$ l
    • 1,开发环境:Matlab 2012b win32
    • 2,编程语言:Matlab# ~( @; L" E: V8 I+ Z' q2 q; A

    8 }$ x  H5 w9 g' Z& e0 B" @2 L0 G3 v1 o4 k# }1 S5 x
    最近需要使用matlab绘制带箭头的直线,发现如下方式可以绘制带箭头的直线
    9 E  {& H9 v+ ]% u9 E8 t& E' a8 t& k' `- Z7 U8 v9 Y9 c" F- ]
    • 1.调用annotation函数绘制二维箭头annotation函数用来在当前图形窗口建立注释对象(annotation对象),它的调用格式如下:
    • (1) annotation(annotation_type)  % 以指定的对象类型,使用默认属性值建立注释对象。
    • (2) annotation('line',x,y)       % 建立从(x(1), y(1))到(x(2), y(2))的线注释对象。
    • (3) annotation('arrow',x,y)      % 建立从(x(1), y(1))到(x(2), y(2))的箭头注释对象。
    • (4) annotation('doublearrow',x,y)% 建立从(x(1), y(1))到(x(2), y(2))的双箭头注释对象。
    • (5) annotation('textarrow',x,y)  % 建立从(x(1),y(1))到(x(2),y(2))的带文本框的箭头注释对象
    • (6) annotation('textbox',[x y w h])  % 建立文本框注释对象,左下角坐标(x,y),宽w,高h.
    • (7) annotation('ellipse',[x y w h])  % 建立椭圆形注释对象。
    • (8) annotation('rectangle',[x y w h])% 建立矩形注释对象。
    • (9) annotation(figure_handle,…)     % 在句柄值为figure_handle的图形窗口建立注释对象。
    • (10) annotation(…,'PropertyName',PropertyValue,…)  % 建立并设置注释对象的属性。
    • (11) anno_obj_handle = annotation(…)  % 返回注释对象的句柄值。4 W! v/ w& d' n& b1 S6 C) R
    ! L4 R' `' K; J! |& V

    ) H" Q# u# ?; X发现annotation绘制带箭头的直线还挺好用,但是唯一的不足就是需要坐标系在[0,1]范围内的标准坐标系,其他坐标系中绘制会报错!!!
    + v: _+ ^9 s& g9 V
    ) D1 N* V" v0 Z$ V' l  w1 V, Q( e于是自己写了一个函数来绘制带箭头的直线,函数如下:, Z. y+ f8 V$ w

    7 }1 r0 {3 `8 s! G+ r+ V# |" I
    • %% 绘制带箭头的直线
    • function drawArrow(start_point, end_point,arrColor,lineColor,arrowSize,lineWidth)
    • % 从start_point到end_point画一箭头,arrColor箭头颜色,arrSize,箭头大小
    • %判断参数多少
    • switch nargin
    •     case 2
    •         arrColor  = 'r';
    •         lineColor = 'b';
    •         arrowSize = 2;
    •         lineWidth = 1;
    •     case 3
    •         lineColor = 'b';
    •         arrowSize = 2;
    •         lineWidth = 1;
    •     case 4
    •         arrowSize = 2;
    •         lineWidth = 1;
    •     case 5
    •         lineWidth = 1;
    • end
    • K                = 0.05;                    % 箭头比例系数
    • theta            = pi / 8;                  % 箭头角度
    • A1 = [cos(theta), -sin(theta);
    •     sin(theta), cos(theta)];                % 旋转矩阵
    • theta = -theta;
    • A2 = [cos(theta), -sin(theta);
    •     sin(theta), cos(theta)];                % 旋转矩阵
    • arrow           = start_point' - end_point';
    • %使得箭头跟直线长短无关(固定值)
    • arrow(arrow>=0) = arrowSize;
    • arrow(arrow<0)  = -arrowSize;
    • arrow_1         = A1 * arrow;
    • arrow_2         = A2 * arrow;
    • arrow_1         = K * arrow_1 + end_point'; % 箭头的边的x坐标
    • arrow_2         = K * arrow_2 + end_point'; % 箭头的变的y坐标
    • hold on;
    • grid on;
    • axis equal;
    • plot([start_point(1), end_point(1)], [start_point(2), end_point(2)],lineColor,'lineWidth',lineWidth);
    • % 三角箭头(填充)
    • triangle_x      = [arrow_1(1),end_point(1),arrow_2(1),arrow_1(1)];
    • triangle_y      = [arrow_1(2),end_point(2),arrow_2(2),arrow_1(2)];
    • fill(triangle_x,triangle_y,arrColor);
    • % 线段箭头(不填充)
    • % plot([arrow_1(1), end_point(1)], [arrow_1(2), end_point(2)],color,'lineWidth',arrowSize);
    • % plot([arrow_2(1), end_point(1)], [arrow_2(2), end_point(2)], color,'lineWidth',arrowSize);
    • hold off;
    • end, v; @* ~- ~" `+ \& T' L; b

    9 n/ k) }! [) L+ u
    " t3 m. B4 }2 h6 l' ~+ K8 f1 P* g
    , O2 g; b- Q9 F$ M( @7 @8 J效果如下:& j5 J% w: q- L$ y
    0 Y$ Z+ H8 K! p' |

    ' k. F, Z7 z4 f
    - T& T* d! t/ S, h, m+ j3 K; W效果完美~~~~
    ' N$ R% {# T7 P0 B/ Z  K' r& ?. u: f

    + U3 E2 [2 a0 R5 [

    该用户从未签到

    2#
    发表于 2020-3-9 17:33 | 只看该作者
    用Matlab绘制任意两点之间带箭头的直线
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-20 22:59 , Processed in 0.125000 second(s), 26 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表