• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 在两个可移动的 uiview 之间画线

[复制链接]
菜鸟教程小白 发表于 2022-12-12 09:57:20 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我有一个带有节点(UIViews)的“ ScrollView ”,可以四处拖动。我正在尝试使用“calayer”在选定的 UIViews 之间绘制边缘,但我无法弄清楚当 View 位置发生变化时如何重绘线。

在我的 viewController 类中,我将节点数组中第一个和第二个之间的边添加为:

EdgeLayer *edge = [[EdgeLayer alloc]init];
edge.delegate = self;
edge.strokeColor = [UIColor colorWithWhite:0.25 alpha:1.0];
edge.strokeWidth = 0.5;
edge.startNode = [nodes objectAtIndex:0];
edge.endNode = [nodes objectAtIndex:1];
edge.frame = scrollView.bounds;
[scrollView.layer addSublayer:edge];
[edge setNeedsDisplay];

EdgeLayer.h:

#import <Foundation/Foundation.h>
#import <QuartzCore/QuartzCore.h>

@interface EdgeLayer : CALayer
@property (nonatomic, strong) UIColor *fillColor;
@property (nonatomic) CGFloat strokeWidth;
@property (nonatomic, strong) UIColor *strokeColor;
@property (nonatomic) UIView *startNode;
@property (nonatomic) UIView *endNode;
@end

EdgeLayer.m:

#import "EdgeLayer.h"
#import "NodeView.h"

@implementation EdgeLayer

@synthesize fillColor, strokeColor, strokeWidth;
- (id)init {
    self = [super init];
    if (self) {
    self.fillColor = [UIColor grayColor];
    self.strokeColor = [UIColor blackColor];
    self.strokeWidth = 1.0;
    [self setNeedsDisplay];
}

return self;
}

- (void) setStartNodeNodeView*)startNode
{
     _startNode = startNode;
     [self setNeedsDisplay];
}

- (void) setEndNodeNodeView*)endNode
{
    _endNode = endNode;
    [endNode addObserver:self forKeyPath"endNode" options:NSKeyValueObservingOptionNew context:nil];
    [self setNeedsDisplay];
 }

-(id)initWithLayerid)layer
{
    self = [super initWithLayer:layer];
    return self;
}

-(void) observeValueForKeyPathNSString *)keyPath ofObjectid)object change:    (NSDictionary *)change contextvoid *)context
{
    if ([keyPath isEqualToString"endNode"] )
    {
    // process here
    }
    NSLog(@"View changed its geometry");
}

- (void)drawInContextCGContextRef)ctx
{
    NSLog(@"DRAW");

    CGContextSetStrokeColorWithColor(ctx, [UIColor blackColor].CGColor);
    CGContextSetLineWidth(ctx, 2);
    CGContextMoveToPoint(ctx, _startNode.center.x, _startNode.center.y);
    CGContextAddLineToPoint(ctx, _endNode.center.x, _endNode.center.y);
    CGContextStrokePath(ctx);
}
@end

这从第一个和第二个节点的中心位置添加一条线。我试图为端节点添加一个观察者,但我认为我做得不对。我无法触发 observeValueForKeyPath 方法。我的猜测是我在错误的地方添加了观察者。



Best Answer-推荐答案


问题不在于您添加观察者的位置,而在于您要观察的内容——您使用 endNode 作为 endNode 上的 keyPath,这将不起作用(无论如何,当您拖动时,endNode 不会改变)。您要观察的 endNode 的属性是中心。

您只需将您正在观察的 keyPath 更改为“中心”,并更改您的 observeValueForKeyPathfObject:change:context: 的实现:就像这样,

-(void) observeValueForKeyPathNSString *)keyPath ofObjectid)object changeNSDictionary *)change context:(void *)context {
    if ([keyPath isEqualToString"center"] ) [self setNeedsDisplay];
}

我通过将平移手势识别器添加到其中一个 nodeView 来对此进行测试,并且在我拖动时,连接两个节点的线会相应更新。

关于ios - 在两个可移动的 uiview 之间画线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23748451/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap