Swift实时画箭头的实现
iOS上实现画箭头,如果是指定了坐标点,那是很简单的,但如果需要做到实时绘制,就需要计算一下了
需求:
在白板上,根据手势落下点和移动点,实时绘制一条箭头直线(如下图)

实现代码:
/// 获取箭头的点位置
///
/// - Parameters:
/// - fPoint: <#fPoint description#>
/// - tPoint: <#tPoint description#>
/// - Returns: <#return value description#>
func getArrowPoint(fPoint:CGPoint,tPoint:CGPoint) -> (CGPoint,CGPoint,CGPoint) {
var p1 = CGPoint.zero //箭头点1
var p2 = CGPoint.zero //箭头点2
var p3 = CGPoint.zero //箭头最前面点
//假设箭头边长20,箭头是一个等腰三角形
let line = sqrt(pow(fabs(tPoint.x-fPoint.x), )+pow(fabs(tPoint.y-fPoint.y), ))
let arrowH:CGFloat = line> ? : line/
//线与水平方向的夹角
let angle = getAnglesWithThreePoints(p1: fPoint, p2: tPoint, p3: CGPoint(x: fPoint.x, y: tPoint.y))
let _x = CGFloat(fabs(sin(angle)))*arrowH/
let _y = CGFloat(fabs(cos(angle)))*arrowH/
//向右上角、水平向右
if tPoint.x >= fPoint.x && tPoint.y <= fPoint.y{
p1.x = tPoint.x-_x
p1.y = tPoint.y-_y p2.x = tPoint.x+_x
p2.y = tPoint.y+_y p3.x = tPoint.x+_y*
p3.y = tPoint.y-_x* }else if tPoint.x > fPoint.x && tPoint.y > fPoint.y{
//向右下角
p1.x = tPoint.x+_x
p1.y = tPoint.y-_y p2.x = tPoint.x-_x
p2.y = tPoint.y+_y p3.x = tPoint.x+_y*
p3.y = tPoint.y+_x*
}else if tPoint.x < fPoint.x && tPoint.y < fPoint.y{
//向左上角
p1.x = tPoint.x-_x
p1.y = tPoint.y+_y p2.x = tPoint.x+_x
p2.y = tPoint.y-_y p3.x = tPoint.x-_y*
p3.y = tPoint.y-_x* }else if tPoint.x < fPoint.x && tPoint.y >= fPoint.y{
//向左下角,水平向左
p1.x = tPoint.x-_x
p1.y = tPoint.y-_y p2.x = tPoint.x+_x
p2.y = tPoint.y+_y p3.x = tPoint.x-_y*
p3.y = tPoint.y+_x*
}else if fPoint.x==tPoint.x {
//竖直方向
p1.x=tPoint.x-arrowH/
p1.y=tPoint.y
p2.x=tPoint.x+arrowH/
p2.y=tPoint.y
p3.x=tPoint.x
p3.y = tPoint.y>fPoint.y ? tPoint.y+arrowH : tPoint.y-arrowH
} return (p1,p2,p3)
}
其中,获取夹角方法:getAnglesWithThreePoints
/// 计算三点之间的角度
///
/// - Parameters:
/// - p1: 点1
/// - p2: 点2(也是角度所在点)
/// - p3: 点3
/// - Returns: 角度(180度制)
func getAnglesWithThreePoints(p1:CGPoint,p2:CGPoint,p3:CGPoint) -> Double {
//排除特殊情况,三个点一条线
if (p1.x == p2.x && p2.x == p3.x) || ( p1.y == p2.x && p2.x == p3.x){
return
} let a = fabs(p1.x - p2.x)
let b = fabs(p1.y - p2.y)
let c = fabs(p3.x - p2.x)
let d = fabs(p3.y - p2.y) if (a < 1.0 && b < 1.0) || (c < 1.0 && d < 1.0){
return
}
let e = a*c+b*d
let f = sqrt(a*a+b*b)
let g = sqrt(c*c+d*d)
let r = Double(acos(e/(f*g)))
return r //弧度值 // return (180*r/Double.pi) //角度值 }
最后得到三个点,即箭头的三个点坐标

Swift实时画箭头的实现的更多相关文章
- 菱形实现气泡Bubble,菱形画箭头,菱形画三角形
菱形实现气泡Bubble,菱形画箭头,菱形画三角形 >>>>>>>>>>>>>>>>>>&g ...
- android 使用Canvas画箭头
public class MyCanvas extends View{ private Canvas myCanvas; private Paint myPaint=new Pai ...
- SVG 使用marker画箭头(一)
一.使用Marker画箭头 1.定义一个箭头的marker引用 <defs> <marker id='markerArrow' markerWidth='13' markerHeig ...
- WPF画箭头
简介 参考Using WPF to Visualize a Graph with Circular Dependencies的基础上写了一个WPF画箭头的库. 效果图如下: 使用的XAML代码如下: ...
- canvas画箭头demo
效果图: 代码: <!DOCTYPE html> <html> <title>canvas画箭头demo</title> <body> &l ...
- D2D画箭头的例子
原文:D2D画箭头的例子 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/sunnyloves/article/details/50830102 用处 ...
- 如何用CorelDRAW画箭头?
CorelDRAW,简称为cdr,是一款专业的矢量绘图软件,在设计界也是常用的专业设计之一,在日常的设计工作中,我们常常需要绘制一些特殊的图形,比如箭头.很多对cdr不是特别熟练的小伙伴不知道如何用c ...
- 在matlab 画箭头
[转载]在matlab 画箭头 原文地址:在matlab 画箭头作者:纯情小郎君 完整见链接http://www.mathworks.com/matlabcentral/fx_files/14056/ ...
- Workflow:采用坐标变换(移动和旋转)画箭头
背景 流程设计器的连线部分需要画一个箭头代表连接的方向,下图是期望的效果: 刚开始我准备采用三角函数(sin和cos)来计算三角的坐标,实现的过程真不爽(有兴趣的朋友可以试试),就在完工的时候,突然想 ...
随机推荐
- HDU 5113
HDU 5113类似四色定理的什么东西,大体就是dfs了,不过有两个坑点,这个题的逼格瞬间就上去了1.剪枝很神奇,任何一种颜色都不能超过剩下总格子数的一半,想想确实显然但是比赛的时候没有想到:2.测评 ...
- Vagrant 管理部署 VirtualBox (推荐使用)
学习一段时间的大数据和容器技术,使用虚拟机搭建实验环境还是挺耗时耗力的. 一旦虚拟机坏掉了,还要重新开始. 最近发现了Vagrant, 简直好用上天,方便快捷,易用. 下面介绍如何在Windows中安 ...
- IIS PHP
Name:PHP_FCGI_MAX_REQUESTS Value:10000
- 《C#图解教程》一览
本书针对编程新手和中级水平的程序员.笔者尽力专注 C# 语言本身,详尽深入地描述语言及各部分.少涉及 .NET 和相关编程实践.本书写作过程中,笔者始终坚持确保内容简洁性的同时又能透彻地讲解这门语言. ...
- php xml格式对象 返回->对应格式数组
/* * $objXml xml格式对象 * 返回 : 对应格式数组 */ public function XmlString2Arr($xml) { ...
- node 将本地项目docker化
vi test.sh docker rm -f kao3 || echo kao3 not exists;docker run -itd \--privileged=true \-v ~/logs:/ ...
- React入门——制作一个TodoList App
源码 import React, { Component, Fragment } from "react"; class TodoList extends Component { ...
- [POJ2287][Tyvj1048]田忌赛马 (贪心+DP)
瞎扯 很经典的一道题 考前才打 我太菜了QAQ 就是先贪心排序了好 然后在DP 这样比直接DP更容易理解 (其实这题做法还有很多) 代码 #include<cstdio> #include ...
- Python并发编程-线程
Python作为一种解释型语言,由于使用了全局解释锁(GIL)的原因,其代码不能同时在多核CPU上并发的运行.这也导致在Python中使用多线程编程并不能实现并发,我们得使用其他的方法在Python中 ...
- keras用vgg16做图像分类
实际上我只是提供一个模版而已,代码应该很容易看得懂,label是存在一个csv里面的,图片是在一个文件夹里面的 没GPU的就不用尝试了,训练一次要很久很久... ## import libaries ...