当前位置:网站首页>Flutter 通过拖拽调整绘制图形
Flutter 通过拖拽调整绘制图形
2022-07-22 09:35:00 【岛上码农】
前言
上一篇我们通过Listener
获取触控点的位置作为贝塞尔曲线的控制点,实现曲线的交互式绘制。不过,上一篇有个缺陷,控制点绘制完成后只能撤销,没法修改,如果要调整绘制的图形的话会非常麻烦,这一篇我们来实现控制点的拖拽式移动,动态调整位置来调整绘制的图形。
实现逻辑
上一篇的主要代码我们不做更改,主要是需要实现控制点的拖拽式移动,移动过程中动态绘制新的曲线。不过由于绘制过程中不能同时移动点,因此需要有个完成绘制的控制,完成绘制后才支持拖拽控制点。拖拽控制点实现这里有两个主要逻辑:
- 控制点的命中判断:即拖拽开始时判断哪个控制点被命中,需要移动。
- 监听触控位置的移动过程:移动过程中动态绘制新的图形,以便直接看到对应的效果。
控制点的命中判断在完成绘制后,首先需要监听触控按下事件,看看触控点是否覆盖了某个控制点的触控响应范围,同时对于距离较近的点,可能会同时命中多个点的触控响应范围,这个时候需要取距离最近的那个点。对于触控范围,我们定义为每个触控点的周边10个像素点。命中触控点的实现代码如下:
int checkPointToMove(Offset pressedPoint) {
// 控制点非空才查找
if (points.isNotEmpty) {
var pointsToCheck = <Offset>[];
final maxDistance = 10.0;
// 查找触控响应范围内的控制点
for (Offset p in points) {
边栏推荐
- 关于人力外包公司那些事
- Leetcode: 627. Change gender
- Programmer interview golden code interview question 01.03. URL
- Flink learning notes (VI) Flink's time and window
- 高手常用的15 种 SQL 优化
- Leetcode:196. delete duplicate email
- [yolov5 practice 4] traffic sign recognition system based on yolov5 - model test and evaluation
- Summary of all usage of join in SQL syntax (simple example)
- MNIST手写数字识别案例TensorFlow 2.0 实践
- LeetCode 每日一题 2022/3/14-2022/3/20
猜你喜欢
Flink learning notes (VI) Flink's time and window
Learning to Incorporate Structure Knowledge for Image Inpainting
关于人力外包公司那些事
融云办政事: “小网格”也能实现“大治理”
mysql执行过程以及顺序
CentOS7安装Mysql5.7解压版&Navicat连接Mysql&防火墙设置——亲测有效
协同办公市场暴增背后:融云通信能力是需求重点
2、 Idea build jfinal project + automatic code generation + database operation test (three ways)
1. Lei Dian: transfer MySQL database to Oracle, 2.qt5.12.3 connect Oracle 12C database
Programmer interview golden code interview question 01.03. URL
随机推荐
深度学习资料整理
2、 Idea build jfinal project + automatic code generation + database operation test (three ways)
C语言 static和extern知识点
Leetcode daily question 2021/12/13-2021/12/19
Leetcode daily question 2022/3/14-2022/3/20
助力品牌洞察——消费者情绪行为分析
How latex abbreviates the author's name to et al when writing references
Leetcode: 185. all employees with the top three highest wages in the Department
1. Create a dynamic library of functions, 2. Howto create and deploy a sample DLL using MinGW
Transformer, another city! The top of many low-level tasks was occupied, and Peking University Huawei and others jointly proposed the pre training model IPT
OSI seven layer network model
LeetCode 每日一题 2022/3/28-2022/4/3
LeetCode 每日一题 2022/1/24-2022/1/30
Shell script debugging technology
mysql执行过程以及顺序
高手常用的15 种 SQL 优化
Flink learning notes (III) Flink installation and deployment
LeetCode 每日一题 2021/12/13-2021/12/19
服务器运维环境安全体系(上篇)
LeetCode 每日一题 2021/12/27-2022/1/2