NSScroll 视图中的 contentsize 和 contentOffset 等效项

时间:2022-12-28
本文介绍了NSScroll 视图中的 contentsize 和 contentOffset 等效项的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在将应用程序从 Ipad 移植到 mac.(我知道这听起来很奇怪)

I am porting an app from Ipad to mac. (I know that it sounds weird)

我坚持使用 NSScrollview.请指导我 contentsize , contentOffset 在 NSScrollview 中等效.

I stuck with NSScrollview. Please guide me contentsize , contentOffset equivalent in NSScrollview.

推荐答案

UIScrollView* uiScroll;
uiScroll.contentSize;
uiScroll.contentOffset;
uiScroll.contentSize = CGSizeMake(w,h);
uiScroll.contentOffset = CGPointMake(x,y);

=

NSScrollView* nsScroll;
nsScroll.documentView.frame.size;
nsScroll.documentVisibleRect.origin;
nsScroll.documentView.frameSize = NSMakeSize(w,h);
[nsScroll.documentView scrollPoint:NSMakePoint(x,y)];

或者甚至更好:

import AppKit

extension NSScrollView {
    var documentSize: NSSize {
        set { documentView?.setFrameSize(newValue) }
        get { documentView?.frame.size ?? NSSize.zero }
    }
    var documentOffset: NSPoint {
        set { documentView?.scroll(newValue) }
        get { documentVisibleRect.origin }
    }
}

注意:我使用了documentSize"(和documentOffset"),因为contentSize"与 NSScrollView 的现有属性冲突.

Notes: I used 'documentSize' (and 'documentOffset') because 'contentSize' conflicts with an already existing property of NSScrollView.

这篇关于NSScroll 视图中的 contentsize 和 contentOffset 等效项的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

上一篇:在 UIScrollView 上更改页面 下一篇:在 iOS 6 上使用自动布局在 ScrollView 中嵌入 Image

相关文章

最新文章