关闭

MacOS 开发 - NSPopover

标签: NSPopoverMacOSNSAppearan
2214人阅读 评论(2) 收藏 举报
分类:

简介

Mac 中常见点击状态栏图标,或者点击按钮,会出现带尖角的视图,就是 NSPopover。

创建和使用

下面直接展示代码让大家了解怎么使用:
1、为了省时,直接拉取 NSButton 到 xib , 并将按钮拖线到 .m文件,写下 - (IBAction)btn0OnClick:(id)sender {} 方法。

2、创建 FirstViewController.h 继承自 NSViewController, 建议勾选同时创建 xib。
这个控制器就是 popover 中显示的内容。我们也可以把 NSPopover 理解为一个容器。

3、在 .m 文件中,创建两个属性,并进行懒加载。
不喜欢懒加载的小伙伴,也可以用我的懒加载自动生成工具:
/lovechris00/article/details/77448356

@property(nonatomic,strong) NSPopover *firstPopover;
@property(nonatomic,strong) FirstViewController * firstVC;

- (NSPopover *)firstPopover
{
    if(!_firstPopover)
    {
        _firstPopover=[[NSPopover alloc]init];

        _firstPopover.appearance = [NSAppearance appearanceNamed:NSAppearanceNameAqua];

        _firstPopover.contentViewController = self.firstVC;
        _firstPopover.behavior = NSPopoverBehaviorTransient;

    }
    return _firstPopover;
}

- (FirstViewController *)firstVC
{
    if(!_firstVC)
    {
        _firstVC=[[FirstViewController alloc]init];
    }
    return _firstVC;
}

4、在按钮方法中调出这个 popOver

- (IBAction)btn0OnClick:(id)sender {

    NSButton *button = sender;
    //显示在button 下面
    [self.firstPopover showRelativeToRect:[button bounds] ofView:button preferredEdge:NSRectEdgeMaxY];

}

5、为了丰富 弹窗的内容,你可以往 FirstViewController.xib 中添加内容测试。


细节

如何控制 popover 窗口大小?

答:调整 popover 中控制器的大小即可,比如我调整了 xib 的尺寸。

pop


NSPopover 的 appearance

系统定义了四种 Standard Appearances

NSAppearanceNameAqua 
NSAppearanceNameLightContent 
NSAppearanceNameVibrantDark 
NSAppearanceNameVibrantLight //默认

效果直接上图了:

NSAppearanceNameAqua

NSAppearanceNameLightContent

NSAppearanceNameVibrantDark

NSAppearanceNameVibrantLight


弹出样式 NSPopoverBehavior

typedef NS_ENUM(NSInteger, NSPopoverBehavior) {
    NSPopoverBehaviorApplicationDefined = 0,  
    NSPopoverBehaviorTransient = 1,
    NSPopoverBehaviorSemitransient = 2
};
  • 弹出的效果上没有什么区别
  • NSPopoverBehaviorApplicationDefined 点击其他地方,不会自动消失。

出现的方位 NSRectEdge

typedef NS_ENUM(NSUInteger, NSRectEdge) {
    NSRectEdgeMinX = CGRectMinXEdge, //按钮右侧
    NSRectEdgeMinY = CGRectMinYEdge, //上方
    NSRectEdgeMaxX = CGRectMaxXEdge, //左侧
    NSRectEdgeMaxY = CGRectMaxYEdge, //下面

}

补充

前任遇到一个坑:
http://www.jianshu.com/p/e00ddf1e8475
问题:“今天开发 iTips,遇到一个很诡异的问题:NSOutlineView 中的 NSTableCellView 中的 NSTextField,始终有一个背景色,无论怎么设置都无法去掉。”
原因:“才发现NSPopover 默认使用 NSAppearanceNameVibrantLight 这种样式,因此带来问题:NSTextField 使用透明背景色,进而就会取 NSPopover 中的背景色,就是图中的问题。”

解决方案:只要将 NSPopover 的主题改为 NSAppearanceNameAqua 即可:

self.view.appearance = NSAppearance(named: NSAppearanceNameAqua)


参考资料

0
0
查看评论
发表评论
* 以上用户言论只代表其个人钱柜娱乐开户,不代表CSDN网站的钱柜娱乐开户或立场

NSPopover使用

- (IBAction)alertButton:(id)sender {     mypopoverView = [[MyPopoverViewController alloc] initWit...
  • qq_27740983
  • qq_27740983
  • 2015-12-16 17:03
  • 1469

MAC NSPopover

下面通过NSStatusBar出发 NSPopver。 创建 NSStatusBar//获取系统单例NSStatusBar对象 NSStatusBar *statusBar = [NSSta...
  • tongwei117
  • tongwei117
  • 2017-05-05 10:53
  • 380

如何改变NSPopover的背景颜色(包括小三角部分)?

问题:在OSX开发时,经常会使用NSPopover来弹出小窗口,那么如何改变NSPopover的背景颜色(包括小三角部分)? 解答:此方案不需要其他第三方库,仅需引入两个自定义NSView类。
  • left_la
  • left_la
  • 2015-08-14 11:18
  • 3017

Popover 初探

Popover 是一个新型的弹出窗口。  apple 文档里面这样说:  NSPopover类提供了一种方法在现有相关内容在屏幕上显示更多的内容。Popover窗口定位相对于现有内容。 ...
  • xianlaowu
  • xianlaowu
  • 2015-10-26 23:19
  • 584

Mac OS X开发者值得收藏的开发资源

本文主要给大家介绍几个Mac开发中值得收藏的三方控件,有些是经过自己改造的,这也主要源于在实习期间,做了几个月的Mac开发,在开发期间也收集和改造了一些三方的控件。
  • wlaizff
  • wlaizff
  • 2016-03-02 18:20
  • 1351

使用Swift开发一个MacOS的菜单状态栏App

这两天突然想看看OSX下的App开发,看了几篇文章。下面这一篇我觉得入门是非常好的。我仅转述为中文,并非原文翻译。原文地址:http://footle.org/WeatherBar/ 下面开始介绍如...
  • yanghuiliu
  • yanghuiliu
  • 2016-07-28 12:11
  • 6659

学习Mac开发第三弹 通过WebView加载网页

学习Mac开发第三弹 通过WebView加载网页 添加WebKit.framework  关联Delegate 在新建工程的ViewController里拖放一个WebView,并用...
  • lengshengren
  • lengshengren
  • 2016-12-28 20:02
  • 2272

使用Swift开发一个MacOS的菜单状态栏App

这两天突然想看看OSX下的App开发,看了几篇文章。下面这一篇我觉得入门是非常好的。我仅转述为中文,并非原文翻译。原文地址:http://footle.org/WeatherBar/ 下面开始介绍如...
  • yanghuiliu
  • yanghuiliu
  • 2016-07-28 12:11
  • 6659

MacOS 搭建钱柜娱乐开户开发环境

如何在MAC OS X 安装钱柜娱乐开户 SDK我以往用的开发环境都是以MAC OS安装VMware来跑不同的Windows OS,目前慢慢的将所要开发的项目由以往的传统的Wintel转移到Mobi...
  • ttth202507
  • ttth202507
  • 2011-06-11 12:46
  • 8223

macOS系统下搭建钱柜娱乐开户开发环境

在开始搭建钱柜娱乐开户开发环境之前,或者在学习钱柜娱乐开户开发之前,建议先学习Java入门知识。 Mac OS X系统在10.12.0起正式更名为“macOS”。 下面将从钱柜娱乐开户 SD...
  • fjnu_se
  • fjnu_se
  • 2017-06-06 19:55
  • 243
    钱柜娱乐开户
    个人资料
    • 访问:192741次
    • 积分:3225
    • 等级:
    • 排名:第12255名
    • 原创:123篇
    • 转载:6篇
    • 译文:1篇
    • 评论:97条
    最新评论