cocoa – 多次调用updateTrackingAreas方法

cocoa – 多次调用updateTrackingAreas方法,第1张

概述在我的项目中有一个带有NSButton的窗口和一个NSView(它是其他视图的容器).单击该按钮可更改容器的子视图,如下所示: [containerView replaceSubview:displayedSubview with:nextView]; 添加到containerView的第一个子视图有一个基于视图的TableView(使用绑定)填充NSTableCellView子类的对象. 这个子 在我的项目中有一个带有NS@R_419_5554@的窗口和一个NSVIEw(它是其他视图的容器).单击该按钮可更改容器的子视图,如下所示:

[containerVIEw replaceSubvIEw:displayedSubvIEw with:nextVIEw];

添加到containerVIEw的第一个子视图有一个基于视图的tableVIEw(使用绑定)填充NStableCellVIEw子类的对象.

这个子类NStableCellVIEw有一个跟踪区域,当鼠标进入/离开单元格时,它允许我显示/隐藏按钮.

方法mouseEntered:和mouseExited:分别使用setAlphaValue:方法显示和隐藏_@R_419_5554@InsIDetableCellVIEw.

跟踪区域在init方法中创建如下:

NSTrackingAreaOptions options = NSTrackingMouseEnteredAndExited|NSTrackingActiveInActiveApp;_trackingArea  = [[NSTrackingArea alloc] initWithRect:[self bounds] options:options owner:self userInfo:nil];

updateTrackingAreas方法很简单:

- (voID)updateTrackingAreas{    [_@R_419_5554@InsIDetableCellVIEw setAlphaValue:0.0];    [self removeTrackingArea:_trackingArea];    NSTrackingAreaOptions options = NSTrackingMouseEnteredAndExited|NSTrackingActiveInActiveApp;    _trackingArea  = [[NSTrackingArea alloc] initWithRect:[self bounds] options:options owner:self userInfo:nil];    [self addTrackingArea:_trackingArea];    [super updateTrackingAreas];}

问题

当程序启动时,一切都按预期工作:如果鼠标在单元格上,则显示其按钮.

但是在我将containerVIEw的子视图更改为nextVIEw并返回到第一个视图后,当替换子视图时,当应用程序变为活动状态(???)时,方法updateTrackingAreas开始被多次调用(2次或更多次)进入或离开trackingArea(???).

调用堆栈

如果我在updateTrackingAreas中放置一个断点,这是调用堆栈:

#0  0x0000000100019e33 in -[CustomtableCellVIEw updateTrackingAreas]#1  0x00007fff8a1b24e4 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#2  0x00007fff894740b6 in __NSArrayEnumerate ()#3  0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#4  0x00007fff894740b6 in __NSArrayEnumerate ()#5  0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#6  0x00007fff894740b6 in __NSArrayEnumerate ()#7  0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#8  0x00007fff894740b6 in __NSArrayEnumerate ()#9  0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#10 0x00007fff8a1b36bd in -[NSScrollVIEw _updateTrackingAreas] ()#11 0x00007fff894740b6 in __NSArrayEnumerate ()#12 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#13 0x00007fff894740b6 in __NSArrayEnumerate ()#14 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#15 0x00007fff894740b6 in __NSArrayEnumerate ()#16 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#17 0x00007fff894740b6 in __NSArrayEnumerate ()#18 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#19 0x00007fff894740b6 in __NSArrayEnumerate ()#20 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#21 0x00007fff894740b6 in __NSArrayEnumerate ()#22 0x00007fff8a1b2960 in -[NSVIEw(NSInternal) _updateTrackingAreas] ()#23 0x00007fff8a1b237c in _handleInvalIDCursorRectsNote ()#24 0x00007fff8a6ac851 in __35-[NSWindow _postInvalIDCursorRects]_block_invoke_02794 ()#25 0x00007fff894420c7 in __CFRUNLOOP_IS_CALliNG_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ ()#26 0x00007fff89442031 in __CFRunLoopDoObservers ()#27 0x00007fff8941d4a8 in __CFRunLoopRun ()#28 0x00007fff8941cdd2 in CFRunLoopRunspecific ()#29 0x00007fff89a72774 in runcurrentEventLoopInMode ()#30 0x00007fff89a72454 in ReceiveNextEventCommon ()#31 0x00007fff89a723a3 in BlockUntilNextEventMatchingListInMode ()#32 0x00007fff8a0d7fa3 in _DPSNextEvent ()#33 0x00007fff8a0d7862 in -[NSApplication nextEventMatchingMask:untilDate:inMode:dequeue:] ()#34 0x00007fff8a0cec03 in -[NSApplication run] ()#35 0x00007fff8a073656 in NSApplicationMain ()#36 0x00000001000013a2 in main#37 0x0000000100001374 in start ()
解决方法 目前尚不清楚这里存在问题.当视图几何体发生变化或者只要感觉需要重新计算跟踪区域时,appTrait会多次调用updateTrackingAreas方法.例如,在动画的情况下,当边界随时间快速变化时,您的方法将在每个runloop中快速连续调用.

仅供参考,改变任何视图的状态可能不是一个好主意,或者除了在该方法中添加或删除跟踪区域之外还有其他任何 *** 作.在这里,您将更改按钮的Alpha状态.这可能最好放在其他地方.

总结

以上是内存溢出为你收集整理的cocoa – 多次调用updateTrackingAreas方法全部内容,希望文章能够帮你解决cocoa – 多次调用updateTrackingAreas方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1001051.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存