/*
软件作者:https://xuhss.com/oxox/pro
*/
"auto";
/*
cp在此是四個元素的陣列:
cp[0]為起始點,或上圖中的P0
cp[1]為第一個控制點,或上圖中的P1
cp[2]為第二個控制點,或上圖中的P2
cp[3]為結束點,或上圖中的P3
t為參數值,0 <= t <= 1
*/
function PointOnCubicBezier( cp, t )
{
var ax, bx, cx;
var ay, by, cy;
var tSquared, tCubed;
var result ,result_x,result_y;
/*計算多項式係數*/
cx = 3.0 * (cp[1].x - cp[0].x);
bx = 3.0 * (cp[2].x - cp[1].x) - cx;
ax = cp[3].x - cp[0].x - cx - bx;
cy = 3.0 * (cp[1].y - cp[0].y);
by = 3.0 * (cp[2].y - cp[1].y) - cy;
ay = cp[3].y - cp[0].y - cy - by;
/*計算位於參數值t的曲線點*/
tSquared = t * t;
tCubed = tSquared * t;
result_x = (ax * tCubed) + (bx * tSquared) + (cx * t) + cp[0].x;
result_y = (ay * tCubed) + (by * tSquared) + (cy * t) + cp[0].y;
result={x:result_x,y:result_y};
return result;
}
/*
ComputeBezier以控制點cp所產生的曲線點,填入Point2D結構的陣列。
呼叫者必須分配足夠的記憶體以供輸出結果,其為<sizeof(Point2D) numberOfPoints>
*/
function ComputeBezier( cp, numberOfPoints, curve )
{
var dt;
var i;
dt = 1.0 / ( numberOfPoints - 1 );
for( i = 0; i < numberOfPoints; i++)
curve[i] = PointOnCubicBezier( cp, i*dt );
}
var cp=[
{x:194, y:405}, {x:735, y:876}, {x:537, y:1383}, {x:846, y:1666}
];
var numberOfPoints=100;
var curve=[];
ComputeBezier( cp, numberOfPoints, curve );//列表 对象
var i=0;
var ra = new RootAutomator();
//让"手指1"点击位置(100, 100)
ra.touchDown(194, 405);
//让"手指2"点击位置(200, 200);
setInterval(function (){
var j = (i<100)?i:(199-i);
xx=curve[j].x
yy=Math.abs(100-curve[j].y)
log(xx,yy)
ra.touchMove(xx,yy);
if(++i==200)i=0;
}, 10);
[虚幻私塾】
- 粉丝: 336
- 资源: 1558
最新资源
- gshhg-bin-2.3.7.zip
- 上市公司绿色创新持续性水平(OIP)测算数据集1991-2022.xlsx
- 施工人员检测15-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar
- 海康威视Hikvision MVA V4.3.3.0 海康硬盘录像机播放工具
- 施工人员检测14-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar
- 第01章 Linux系统概述
- JavaSwing+mysql图书管理系统完整源码+数据库(高分项目)
- 史上最简单最容易让web初学者理解的基础知识(仅针对个人)
- delphi IDE 插件DelphiIDEPlugin-SearchProject,用于从项目组中查找项目
- 施工人员检测12-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈