飞道的博客

MATLAB实时获取鼠标移动数据--轨迹生成前篇0

455人阅读  评论(0)

1、前记:

人机交互的方式--键盘开关、鼠标、触摸屏、体感传感器(Kinect、leap motion)语音识别等的使用大大促进人与机器的交互过程。这里记录鼠标事件与MATLAB的结合,为后期机器人仿真控制打下基础---如鼠标直接拖动机器人运动(像很多机器人仿真软件里的作用一样,如Robotstudio、soldworks、proe\core、Adams等)。
这是写在 MATLAB鼠标事件应用(记录)之中的前言部分。如今时间过去了这么久,原本打算在MATLAB中自己造轮子实现一个能拖拽完成机器人运动的交互功能,当然自己足够菜且没有足够的时间所以没能实现。但去年在介绍MATLAB机器人系统工具箱【MATLAB 2020b版本发布,下载试用版并上手使用记录。】的时候发现官网已经使用了interactiveRigidBodyTree对刚体树进行拖拽示教的功能。


  
  1. lbr = importrobot( 'iiwa14.urdf') ;
  2. lbr.Gravity=[ 0 0 - 9.80665] ;
  3. iviz = interactiveRigidBodyTree(lbr) ;

                                                      

关于利用鼠标的轨迹只是简单的完成了一个写字的demo:Robot write words Using Robotics toolbox

而且这个里面使用的是前面链接中的第4个例子,将数据保存后作为机器人逆解的输入,当然这里需要对数据进行scaling确保在机器人的可达空间。

为了方便,在此同样贴出鼠标轨迹的代码:


  
  1. function MouseDraw(action)
  2. % MouseDraw 本例展示如何以Handle Graphics来设定滑鼠事件
  3. % (MouseDraw Events)的反应指令(Callbacks)
  4. % 本程序在鼠标移动非常快时,不会造成画“断线”
  5. % global不能传矩阵
  6. global InitialX InitialY FigHandle
  7. if nargin == 0, action = 'start';
  8. end
  9. switch(action)
  10. %%开启图形视窗
  11. case 'start'
  12. FigHandle = figure( 'WindowButtonDownFcn', 'MouseDraw down');
  13. axis([- 600 600 - 600 600]); % 设定图轴范围
  14. % axis off;
  15. grid on;
  16. box on; % 将图轴加上图框
  17. title( '手写体输入窗');
  18. % % fprintf( 'start');
  19. %%设定滑鼠按钮被按下时的反应指令为「MouseDraw down」
  20. % set(gcf, 'WindowButtonDownFcn', 'MouseDraw down');
  21. dlmwrite( 'IXT.txt', 10, 'delimiter', '\t', 'precision', 10);
  22. dlmwrite( 'IZT.txt', 10, 'delimiter', '\t', 'precision', 10);
  23. %%滑鼠按钮被按下时的反应指令
  24. case 'down'
  25. if strcmp(get(FigHandle, 'SelectionType'), 'normal') %如果是左键
  26. set(FigHandle, 'pointer', 'hand');
  27. CurPiont = get(gca, 'CurrentPoint');
  28. InitialX = CurPiont( 1, 1);
  29. InitialY = CurPiont( 1, 2);
  30. dlmwrite( 'IXT.txt', InitialX, '-append', 'delimiter', '\t', 'precision', 10);
  31. dlmwrite( 'IZT.txt', InitialY, '-append', 'delimiter', '\t', 'precision', 10);
  32. % 列印「MouseDraw down!」讯息
  33. % % fprintf( 'MouseDraw down!\n');
  34. % 设定滑鼠移动时的反应指令为「MouseDraw move」
  35. set(gcf, 'WindowButtonMotionFcn', 'MouseDraw move');
  36. set(gcf, 'WindowButtonUpFcn', 'MouseDraw up');
  37. elseif strcmp(get(FigHandle, 'SelectionType'), 'alt') % 如果是右键
  38. set(FigHandle, 'Pointer', 'arrow');
  39. set( FigHandle, 'WindowButtonMotionFcn', '')
  40. set(FigHandle, 'WindowButtonUpFcn', '')
  41. fprintf( 'MouseDraw right button down!\n');
  42. ImageX = importdata( 'IXT.txt');
  43. ImageY = importdata( 'IZT.txt');
  44. InputImage = ones(imSize);
  45. roundX = round(ImageX);
  46. roundY = round(ImageY);
  47. for k = 1:size(ImageX, 1)
  48. if 0<roundX(k) && roundX(k)<imSize && 0<roundY(k) && roundY(k)<imSize
  49. InputImage(roundX(k)- 1:roundX(k)+ 2, roundY(k)- 1:roundY(k)+ 2) = 0;
  50. end
  51. end
  52. InputImage = imrotate(InputImage, 180); % 图像旋转
  53. figure( 2);
  54. imshow(InputImage);
  55. end
  56. %%滑鼠移动时的反应指令
  57. case 'move'
  58. CurPiont = get(gca, 'CurrentPoint');
  59. X = CurPiont( 1, 1);
  60. Y = CurPiont( 1, 2);
  61. % 当鼠标移动较快时,不会出现离散点。
  62. % 利用y=kx+b直线方程实现。
  63. x_gap = 1; % 定义x方向增量
  64. y_gap = 1; % 定义y方向增量
  65. if X > InitialX
  66. step_x = x_gap;
  67. else
  68. step_x = -x_gap;
  69. end
  70. if Y > InitialY
  71. step_y = y_gap;
  72. else
  73. step_y = -y_gap;
  74. end
  75. % 定义x,y的变化范围和步长
  76. if abs(X-InitialX) < 0.1 % 线平行于y轴,即斜率不存在时
  77. iy = InitialY:step_y:Y;
  78. ix = X.*ones( 1,size(iy, 2));
  79. else
  80. ix = InitialX:step_x:X ; % 定义x的变化范围和步长
  81. % 当斜率存在,即k = (Y-InitialY)/(X-InitialX) ~= 0
  82. iy = (Y-InitialY)/(X-InitialX).*(ix-InitialX)+InitialY;
  83. end
  84. ImageX = [ix, X];
  85. ImageY = cat( 2, iy, Y);
  86. line(ImageX,ImageY, 'marker', '.', 'markerSize', 1, ...
  87. 'LineStyle', '-', 'LineWidth', 2, 'Color', 'Blue');
  88. dlmwrite( 'IXT.txt', ImageX, '-append', 'delimiter', '\t', 'precision', 10);
  89. dlmwrite( 'IZT.txt', ImageY, '-append', 'delimiter', '\t', 'precision', 10);
  90. InitialX = X; %记住当前点坐标
  91. InitialY = Y; %记住当前点坐标
  92. % 列印「MouseDraw is moving!」及滑鼠现在位置
  93. % fprintf( 'MouseDraw is moving! Current location = (%g, %g)\n', ...
  94. % CurPiont( 1, 1), CurPiont( 1, 2));
  95. % % fprintf( 'MouseDraw move!\n');
  96. % 设定滑鼠按钮被释放时的反应指令为「MouseDraw up」
  97. % set(gcf, 'WindowButtonUpFcn', 'MouseDraw up');
  98. %%滑鼠按钮被释放时的反应指令
  99. case 'up'
  100. % 清除滑鼠移动时的反应指令
  101. set(gcf, 'WindowButtonMotionFcn', '');
  102. % 清除滑鼠按钮被释放时的反应指令
  103. set(gcf, 'WindowButtonUpFcn', '');
  104. % 列印「MouseDraw up!」
  105. % % fprintf( 'MouseDraw up!\n');
  106. end
  107. end

能实现的功能如下展示:【以下的是留下轨迹后,将数据保存下来进行适当scaling,再输入到机器人逆解中,是非即时的。】PUMA仿真的代码链接:https://github.com/xiaosnowqiang/Matlab-for-PUMA-simulation

                                                         

2、如何实时获取鼠标移动数据

好了,前面的回忆差不多打住了。这里主要是记录实时的获取鼠标数据。

代码:


  
  1. function mouseMove ( object, eventdata)
  2. clc
  3. clear
  4. set ( gcf, 'WindowButtonMotionFcn', @mouseMove) ;
  5. C = get ( gca, 'CurrentPoint') ;
  6. X = C( 1, 1) ;
  7. Y = C( 1, 2) ;
  8. line( X,Y, 'marker', '.', 'markerSize', 5, ...
  9. 'LineStyle', '-', 'LineWidth', 4, 'Color', 'Blue') ;
  10. title( gca, ['(X,Y) = (', num2str( C( 1, 1)), ', ',num2str( C( 1, 2)), ')']) ;

效果:

                                           

这样有了一个想法就是如何根据这个基础较实时的生成的轨迹并优化后传给机器人末端?或者如何做轨迹的fitting?

先记录到这里................

此处留一个师兄大佬的demo,期望后面也做出这样的效果:

https://www.zhihu.com/zvideo/1360734078346706944

 

 

 

 

 


转载:https://blog.csdn.net/weixin_39090239/article/details/116176823
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场