返回顶部
首页 > 资讯 > 精选 >Android如何利用控制点的拖拽画一个粽子
  • 846
分享到

Android如何利用控制点的拖拽画一个粽子

2023-06-30 16:06:53 846人浏览 独家记忆
摘要

本文小编为大家详细介绍“Android如何利用控制点的拖拽画一个粽子”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android如何利用控制点的拖拽画一个粽子”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实现逻

本文小编为大家详细介绍“Android如何利用控制点的拖拽画一个粽子”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android如何利用控制点的拖拽画一个粽子”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

实现逻辑

拖拽控制点实现这里有两个主要逻辑:

  • 控制点的命中判断:即拖拽开始时判断哪个控制点被命中,需要移动。

  • 监听触控位置的移动过程:移动过程中动态绘制新的图形,以便直接看到对应的效果。

控制点的命中判断在完成绘制后,首先需要监听触控按下事件,看看触控点是否覆盖了某个控制点的触控响应范围,同时对于距离较近的点,可能会同时命中多个点的触控响应范围,这个时候需要取距离最近的那个点。对于触控范围,我们定义为每个触控点的周边10个像素点。命中触控点的实现代码如下:

int checkPointToMove(Offset pressedPoint) {    // 控制点非空才查找    if (points.isNotEmpty) {      var pointsToCheck = <Offset>[];      final maxDistance = 10.0;      // 查找触控响应范围内的控制点      for (Offset p in points) {        if ((p.dx - pressedPoint.dx).abs() < maxDistance &&            (p.dy - pressedPoint.dy).abs() < maxDistance) {          pointsToCheck.add(p);        }      }            // 未找到      if (pointsToCheck.length == 0) {        return -1;      } else if (pointsToCheck.length == 1) {        // 只有一个点,直接返回        return points.indexOf(pointsToCheck[0]);      } else {        // 有多个点命中,找到距离最近的点返回        Offset point = pointsToCheck[0];        var distance = distanceBetween(pointsToCheck[0], pressedPoint);        for (int i = 1; i < pointsToCheck.length; i++) {          var newDistance = distanceBetween(pointsToCheck[i], pressedPoint);          if (newDistance < distance) {            point = pointsToCheck[i];            distance = newDistance;          }        }        return points.indexOf(point);      }    }    return -1;  }

移动过程的处理就比较简单了,我们已经找到了命中的控制点,那就在触控位置移动监听响应方法onPointerMove中更新控制点位置,并重新绘制即可,代码如下,其中indexOfPointToMove是一个状态变量,即找到的控制点下标:

onPointerMove: ((event) {  if (indexOfPointToMove != -1) {    points[indexOfPointToMove] = event.localPosition;    setState(() {});  }}),

应用

逻辑完成了,我们就来做一个绘制应用吧。考虑端午节快到了,我们尝试来绘制一个粽子的线条画看看。下面是调整前后的对比效果以及调整过程的动图,可以看到,调整后的还是更像粽子一些。

Android如何利用控制点的拖拽画一个粽子

Android如何利用控制点的拖拽画一个粽子

Android如何利用控制点的拖拽画一个粽子

读到这里,这篇“Android如何利用控制点的拖拽画一个粽子”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: Android如何利用控制点的拖拽画一个粽子

本文链接: https://lsjlt.com/news/330425.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android利用控制点的拖拽画一个粽子
    目录前言实现逻辑应用总结前言 上一篇我们通过Listener获取触控点的位置作为贝塞尔曲线的控制点,实现曲线的交互式绘制。不过,上一篇有个缺陷,控制点绘制完成后只能撤销,没法修改,如...
    99+
    2024-04-02
  • Android如何利用控制点的拖拽画一个粽子
    本文小编为大家详细介绍“Android如何利用控制点的拖拽画一个粽子”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android如何利用控制点的拖拽画一个粽子”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实现逻...
    99+
    2023-06-30
  • Android如何利用Flutter path绘制粽子
    本文小编为大家详细介绍“Android如何利用Flutter path绘制粽子”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android如何利用Flutter path绘制粽子”文章能帮助大家解决疑惑,下面跟着小编的...
    99+
    2023-06-30
  • 如何在Android应用中实现一个红点拖拽删除功能
    如何在Android应用中实现一个红点拖拽删除功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。CircleImageView核心代码private void ...
    99+
    2023-05-31
    android roi
  • Android使用WindowManager制作一个可拖动的控件
    效果图如下 第一步:新建DragView继承RelativeLayout package com.rong.activity; import com.rong.test.R...
    99+
    2022-06-06
    Android
  • 利用JavaScript制作一个搞怪的兔子动画效果
    目录前言实现效果图前言 Hello,掘友们好!又是一年新春之际,祝福大家兔年快乐!给大家介绍一个有趣的动效(兼容 IE),页面右下角有一只搞怪的兔子,鼠标在页面中悬停时,兔子会跟着做...
    99+
    2023-01-09
    JavaScript制作搞怪兔子动画 JavaScript兔子动画 JavaScript 动画 JavaScript 兔子
  • 如何在Android中利用ConstraintLayout实现一个动画效果
    这篇文章将为大家详细讲解有关如何在Android中利用ConstraintLayout实现一个动画效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。xml布局:<!-- activit...
    99+
    2023-05-31
    android constraintlayout roi
  • 如何在android中利用RecyclerView实现Item的拖拽排序与滑动删除
    如何在android中利用RecyclerView实现Item的拖拽排序与滑动删除?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。需求和技术分析RecyclerV...
    99+
    2023-05-31
    recyclerview android recycle
  • 如何在Android中利用Drawable绘制一个圆角
    如何在Android中利用Drawable绘制一个圆角?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 创建类RoundCircleDrawable继承Drawablepub...
    99+
    2023-05-30
    android drawable
  • 如何利用VB编写一个远程控制程序
    这篇文章主要为大家展示了“如何利用VB编写一个远程控制程序”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何利用VB编写一个远程控制程序”这篇文章吧。一、所用控件在程序中将使用Winsock控件...
    99+
    2023-06-17
  • 如何利用Three.js制作一个新闻联播开头动画
    今天小编给大家分享一下如何利用Three.js制作一个新闻联播开头动画的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。技术选型...
    99+
    2023-06-30
  • 如何在Android应用中利用Dialog实现一个动画效果
    今天就跟大家聊聊有关如何在Android应用中利用Dialog实现一个动画效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 创建两个动画文件window_in.xml:<&a...
    99+
    2023-05-31
    android dialog roi
  • 如何利用HTML5画出一个坦克的形状
    这篇文章主要讲解了“如何利用HTML5画出一个坦克的形状”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何利用HTML5画出一个坦克的形状”吧! ...
    99+
    2024-04-02
  • 如何在Android中使用SurfaceView制作一个天气动画效果
    如何在Android中使用SurfaceView制作一个天气动画效果?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。首先是最终实现的效果图:初识 SurfaceV...
    99+
    2023-05-31
    android surfaceview sur
  • 如何使用Vue实现一个简单的鼠标拖拽滚动效果插件
    这篇文章主要介绍了如何使用Vue实现一个简单的鼠标拖拽滚动效果插件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 演示事例最近在做...
    99+
    2024-04-02
  • 如何在Android应用中利用节点实现一个进度条
    如何在Android应用中利用节点实现一个进度条?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。main.xml<RelativeLayout xmlns:a...
    99+
    2023-05-31
    android 节点 roi
  • 如何在ASP.NET中利用WebApi实现一个版本控制功能
    本篇文章为大家展示了如何在ASP.NET中利用WebApi实现一个版本控制功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。WebApi版本控制的好处有助于及时推出功能, 而不会破坏现有系统,兼容性...
    99+
    2023-06-06
  • 如何利用Android从0到1实现一个流布局控件
    小编给大家分享一下如何利用Android从0到1实现一个流布局控件,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!前言流布局在在项目中还是会时不时地用到的,比如在搜索历史记录,分类,热门词语等可用标签来显示的,都可以设计成流...
    99+
    2023-06-20
  • 如何在Android应用中利用popupwindow实现一个进入与退出的动画效果
    这篇文章将为大家详细讲解有关如何在Android应用中利用popupwindow实现一个进入与退出的动画效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。具体代码如下所示:<&...
    99+
    2023-05-31
    android popupwindow roi
  • 如何利用JavaScript制作一个酷炫的3D图片
    这篇文章将为大家详细讲解有关如何利用JavaScript制作一个酷炫的3D图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、页面特效效果展示注:上述效果图只是部分效果,原谅我还没有学会自制gif图!二...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作