- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我使用贝塞尔曲线创建了 body 图像图。
在我的 customView 中,我为每个 body 部位创建了大约 62 条贝塞尔曲线!最初所有这些都设置为默认颜色。当用户触摸这些路径中的任何一个时,我试图更改它们的笔触颜色。
一种方法是为每个 bezierPath 声明一个 bool 变量,并相应地切换它们。但我认为这是实现它的困难方法。声明 62 个额外的 bool 变量并管理它们。
这是我正在尝试做的事情:
声明贝塞尔曲线属性:
@property (strong,nonatomic) UIBezierPath * rightEyePath;
@property (strong,nonatomic) UIBezierPath * leftEyePath;
@property (strong,nonatomic) UIBezierPath * nosePath;
@property (strong,nonatomic) UIBezierPath * mouthPath;
.... so on
并在 drawRect 中绘制它们:
_leftEyePath = [UIBezierPath bezierPath];
[_leftEyePath moveToPoint: CGPointMake(...)];
[_leftEyePath addLineToPoint: CGPointMake(...))];
[_leftEyePath closePath];
[_defaultColor setStroke];
_leftEyePath.lineWidth = 0.5;
[_leftEyePath stroke];
在 touchesMove 方法中,我试图更改贝塞尔曲线 strokeColor:
if ([_rightEyePath containsPoint:touchPoint])
{
[_defaultColor setStroke];
_rightEyePath.lineWidth = 0.5;
[_rightEyePath stroke];
}
它没有用,因为我没有调用重绘贝塞尔曲线的 setNeedsDisplay。
如何在 drawRect 中为这 62 个贝塞尔曲线传递不同的颜色而无需声明 62 个 bool 变量。
我正在寻找完成任务的有效方法。
最佳答案
我知道你要求的是 objective-C,但这里有一个伪代码 swift 示例来说明我的意思
设置你需要的枚举器
enum BodyPartEnumerator : Int {
case _rightEyePath = 0
case _leftEyePath = 1
// and all the rest...
}
然后定义你需要的数据结构
struct BodyPartData {
var bodyPartIndex : Int
var bezierPath : UIBezierPath
var selected : Bool
}
为 body 部位定义一个数组
var bodyPartData : [BodyPartData] = []
然后 - 要么对每个 body 部位进行硬编码(如您目前所做的那样),要么(更好)从数据文件中加载点。您可以只存储由 body 部位枚举器索引的顶点
然后,在你的触摸方法中,像这样
for (index, bodyPart) in bodyPartData.enumerated()
{
if bodyPart.bezierPath.contains(touchPoint)
{
bodyPartData[index].selected = true // probably need to clear any previous selections
// redraw display
}
}
关于ios - 如何在不重绘的情况下更改 UIBezierPath strokeColor,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43258574/
我想为 CAShapeLayer 的 strokeColor 设置动画,但在 CABasicAnimation 中我有两个值(from 和 to)。动画火时是否只支持两种颜色?例如,开始时我有 str
在这个 CG 教程挑战中,我们被要求在 for 循环中增加在 View 上绘制的圆圈的颜色。为此,我设置了一个带有颜色的数组,然后尝试通过使用递增的 i++ 移动到索引中的下一个对象来实现前循环内的颜
我正在使用 swift 4。 我写了下面的代码并尝试用笔画画一个圆。 但是,使用下面的代码我无法绘制我想要的圆。 问题是线是从圆心画到外围 (严格来说,是朝向'startAngle'属性的坐标点)。
我使用贝塞尔曲线创建了 body 图像图。 在我的 customView 中,我为每个 body 部位创建了大约 62 条贝塞尔曲线!最初所有这些都设置为默认颜色。当用户触摸这些路径中的任何一个时,我
我正在尝试为 CAShapeLayar 的 strokeColor 属性设置动画。我查看了文档,并指出它是一个可动画的属性。该代码用于动画 postion.y 但不是 strokeColor。我很乐意
我想绘制对角线 View 。 这是我的代码。 override func viewDidAppear(_ animated: Bool) { super.viewDidAppear(anima
我使用六个参数(事件、非事件、有线、压缩、免费和总计)。我创建了一个 CAShapeLayer 类,并在其中创建了一个函数,我可以在其中绘制圆圈,只需添加参数即可。我制作了 CGPath 并在绘制圆圈
我已经动态添加了一个 CSS 类,如下所示: var style = document.createElement('style'); style.id = "highlightSegment"; v
我的问题是,当我尝试将透明设置为 FreeText 注释的 strokeColor 时,添加一个结果注释有黑色边框。 我尝试这样编码: this.addAnnot({ type: "FreeText"
我正在使用 CABasicAnimation 绘制我在数组中使用 CAShapeLayer 的所有 UIBezierPaths CAShapeLayer *shapeLayer = [CAShapeL
使用 this previous 中的答案,我未能在 CAShapeLayer 上设置闪烁笔画的动画效果线程,经过多次搜索后,我找不到使用 CABasicAnimation 为笔画设置动画的其他示例。
当我更改 SKShapeNode 的 .alpha 时,它的 stroke 显示自己好像节点的 .strokeColor 比它的 .fillColor 更亮。将 .lineWidth 设置为 0 会取
试图在 cardView 周围做一些边框(androidx.cardview.widget.CardView) 这是代码: 结果: 还尝试使用自定义形状作为背景( fix_border.xml )
添加我的代码。它正在添加一个带有另一个 alpha 的边框,如阴影。 let sliderLayer = CAShapeLayer() sliderLayer.fillColor = UICo
我是一名优秀的程序员,十分优秀!