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

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

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

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

    [LV.1]初来乍到

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

    EDA365欢迎您登录!

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

    x
    工作环境
    5 `1 ~7 ?. N8 Z6 ?- h8 Y3 c8 i1 ~6 x. `
    • 1,开发环境:Matlab 2012b win32
    • 2,编程语言:Matlab. D+ f9 P0 b2 O0 m6 \! b( J2 d
    ) |8 ?3 f; J4 K  ^: K+ o. D2 c% v

    2 w$ }. X# a. C7 D  z! b) n最近需要使用matlab绘制带箭头的直线,发现如下方式可以绘制带箭头的直线
      D- m5 i0 @$ |
    $ l! b( d# l* R* N: T5 V
    • 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(…)  % 返回注释对象的句柄值。
      7 l* D$ R. H% I
    ; _4 ~4 Q  a! S) i4 W

    & r  p" l( W1 z" V. z" e发现annotation绘制带箭头的直线还挺好用,但是唯一的不足就是需要坐标系在[0,1]范围内的标准坐标系,其他坐标系中绘制会报错!!!
    7 v* r' R, C  ?) ~5 X. A% C' p7 U/ D5 t
    于是自己写了一个函数来绘制带箭头的直线,函数如下:
    9 O. |  V8 Z- R* D' T5 e3 J( h: U( D; _1 l$ n, `! C! X
    • %% 绘制带箭头的直线
    • 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
      ; |' D9 L/ ]. ?+ _5 \

      s6 l8 V- |; V* A' W5 k) K2 d4 W! h" i; Q: f( Y. U
    3 d2 h  |, M; c* T! n' u6 x
    效果如下:) l/ t& }8 m3 `- y

    + Z' ?: V  B% x  g7 O' ] + D7 E# Z5 ]+ M. S$ C4 s% G
    ) B" r% K6 E$ }
    效果完美~~~~
    0 \* ~( W6 z4 z8 _6 E) V! L0 G5 P' ^/ s, i- ?- c# n. A7 K/ V
    2 b$ A. ~) }3 R4 N

    该用户从未签到

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

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-11-24 10:46 , Processed in 0.171875 second(s), 27 queries , Gzip On.

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

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

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