如何在使用NSVisualEffectView时添加按钮

时间:2017-03-13 22:55:33

标签: swift macos cocoa nsvisualeffectview

我使用NSVisualEffectView创建了一个窗口,以获得模糊和圆角。像here

一样

问题是当我有NSVisualEffectView代码时,我在窗口中看不到我的按钮。如果我删除代码,则会显示该按钮。出了什么问题?

AppDelegate.swift中的NSVisualEffectView代码:

func applicationDidFinishLaunching(_ aNotification: Notification) {
        // Insert code here to initialize your application
        guard let window = NSApplication.shared().windows.first else { return }
        let effect = NSVisualEffectView(frame: NSRect(x: 0, y: 0, width: 0, height: 0))
        effect.blendingMode = .behindWindow
        effect.state = .active
        effect.material = .dark
        effect.wantsLayer = true
        effect.layer?.cornerRadius = 15.0
        effect.layer?.masksToBounds = true
        window.isOpaque = false
        window.backgroundColor = .clear
        window.contentView = effect
        window.titlebarAppearsTransparent = true
        window.titleVisibility = .hidden
    }

我在故事板中添加了一些按钮。当我运行项目时,我没有看到任何按钮。

enter image description here

当我从applicationDidFinishLaunching(_ aNotification: Notification)删除所有内容,即NSVisualEffectView代码时,我可以看到按钮。

enter image description here

谁能告诉我发生了什么?

2 个答案:

答案 0 :(得分:2)

我想我应该只在previous question中纠正你,但我没有。

您正在使用Storyboard,为什么要在代码中创建<script type="text/javascript"> function refresh() { //Refresh page implementation here window.opener.location.reload(); window.close(); } </script> ... ... 变量?

在右侧面板(“工具”面板)中搜索NSVisualViewEffect,搜索按钮等(对象库)。

enter image description here

拖动它并根据主视图控制器调整其大小。

要添加模糊效果和模式,请转到“工具”面板中的“Attribites Inspector”

enter image description here

并设置nsvisualeffectviewwindow.backgroundColor = .clear

window.isOpaque = false

现在您可以添加按钮,文本字段并运行项目。您可以看到所有添加的元素。

我希望它有所帮助!

答案 1 :(得分:-1)

window位于您要添加按钮的视图上方,因此按钮位于模糊窗口下方,因此无法看到。为什么不将visualEffectView添加到与按钮相同的视图中?您需要将其插入按钮下方以使按钮可见。