启动图第二篇文章启动图名字生成第二篇

启动图名字生成第二篇

我们写一下配置启动图名字的页面保存按钮的逻辑

@IBAction func saveAction(_ sender: Any) {
    for index in 0..<promptNames.count {
        let view =  tableView.view(atColumn: 0, row: index, makeIfNecessary: false) // 依次获取表
        //格上的自定义cell
        guard let cell:LaunchNameCellView = view as? LaunchNameCellView else {
            continue
        }
        guard !cell.launchNameTextFiled.stringValue.isEmpty else {
            continue
        }
        promptValues[index] = cell.launchNameTextFiled.stringValue
    }

}

我们在之前的OFileManger类里面写一个保存我们启动图名字的方法。

/// 保存自定配置的启动图的名称
///
/// - Parameter list: 启动图名称的列表
func saveLaunchNames(list:[String])  {
    let userDefaults = UserDefaults.standard
    userDefaults.set(list, forKey: SLaunchNameKey)
    userDefaults.synchronize()
}

/// 读取保存的启动图的名称列表
///
/// - Returns: 字符串数组 可能读取不出来
func readLaunchNames() -> [String]? {
    let userDefaults = UserDefaults.standard
    return userDefaults.object(forKey: SLaunchNameKey) as? [String]
}

我们在点击保存按钮之后让执行保存的方法还有消失试图

SFileManger.saveLaunchNames(list: promptValues)
self.dismiss(nil)

我们在NSViewController下面的方法写逻辑,让弹出配置启动图试图时候把我们本地的配置传递过去

override func prepare(for segue: NSStoryboardSegue, sender: Any?) {
    let any = segue.destinationController
    guard let controller:LaunchNameViewController = any as? LaunchNameViewController else {
        return
    }
    guard let list = SFileManger.readLaunchNames() else {
        return
    }
    controller.promptValues = list
}

经过发现NSImage属性的Size不是真正的分辨率的大小,我们需要用到

open var representations: [NSImageRep] { get }

属性,里面的NSImageRep里面的

open var pixelsWide: Int

open var pixelsHigh: Int

我们写一个给NSImage写一个扩展的属性sSize

extension NSImage {
    var sSize:NSSize {
        get {
            var size = NSZeroSize
            if representations.count > 0 {
                let rep = representations[0]
                size = NSSize(width: rep.pixelsWide, height: rep.pixelsHigh)
            }
            return size
        }
    }
}

写一下保存的逻辑

class func saveLaunchImages(list:[NSImage], names:[String]) {
    let savePannel = NSOpenPanel()
    savePannel.canCreateDirectories = true
    savePannel.canChooseFiles = false
    savePannel.canChooseDirectories = true
    let index = savePannel.runModal()
    guard index == NSFileHandlingPanelOKButton else {
        return
    }
    guard let dic = savePannel.directoryURL else {
        return
    }
    for index in 0..<names.count {
        for image in list {
            let image640x960HD = index == 0 && NSEqualSizes(image.sSize, NSSize.init(width: 640, height: 960))
            let image640x960 = index == 1 && NSEqualSizes(image.sSize, NSSize.init(width: 640, height: 960))
            let image640x1136 = index == 2 && NSEqualSizes(image.sSize, NSSize.init(width: 640, height: 1136))
            let image750x1334 = index == 3 && NSEqualSizes(image.sSize, NSSize.init(width: 750, height: 1334))
            let image1242x2208 = index == 4 && NSEqualSizes(image.sSize, NSSize.init(width: 1242, height: 2208))
            if image640x960 || image640x960HD || image640x1136 || image750x1334 || image1242x2208 {
                let name = names[index]
                let fileName = "\(dic.absoluteString)\(name)"
                saveImage(image: image, name: fileName)
            }
        }
    }
}

class func saveImage(image:NSImage, name:String) {
    guard let file = URL.init(string: name) else {
        return
    }
    do {

        try image.tiffRepresentation?.write(to:file )
    } catch _ {

    }
}

后来有一个一键可以直接拖拽 这个功能我们百度一下怎么写?

方法基本就是NSDraggingSource, NSDraggingDestination, NSPasteboardItemDataProvider这些代理,你可以看看这个例子https://github.com/phaibin/DragDropDemo

注册接受文件的类型

override func awakeFromNib() {
    register(forDraggedTypes: [NSFilenamesPboardType])
}

完成拖拽的逻辑

override func draggingEntered(_ sender: NSDraggingInfo) -> NSDragOperation {
    guard let type = sender.draggingPasteboard().types else {
        return NSDragOperation.generic
    }
    if type.contains(NSStringPboardType) {
        isDrag = true
        self.isHighlighted = true
        return NSDragOperation.copy
    }
    return NSDragOperation.generic
}
override func draggingExited(_ sender: NSDraggingInfo?) {
    isDrag = false
    self.isHighlighted = true
}

override func prepareForDragOperation(_ sender: NSDraggingInfo) -> Bool {
    isDrag = false;
    self.isHighlighted = true
    return true;
}

override func performDragOperation(_ sender: NSDraggingInfo) -> Bool {

    guard let list = sender.draggingPasteboard().propertyList(forType: NSFilenamesPboardType) as? [String] else {
        return false
    }
    UserDefaults.standard.set(list, forKey: "dragListImage")
    UserDefaults.standard.synchronize()
    return true
}

class func readDragImageList() -> [String]? {
    return UserDefaults.standard.object(forKey: "dragListImage") as? [String]
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏码云1024

MFC多线程

54660
来自专栏kwcode

找到多个与名为“Home”的控制器匹配的类型的解决方案

 主地址:http://localhost:3412/Home/Index 区域地址:http://localhost:3412/T200/Home/Index...

527110
来自专栏王清培的专栏

.NET/ASP.NET MVC Controller 控制器(IController控制器的创建过程)

阅读目录: 1.开篇介绍 2.ASP.NETMVC IControllerFactory 控制器工厂接口 3.ASP.NETMVC DefaultControl...

25460
来自专栏小勇DW3

并发工具箱 concurrent包的原理分析以及使用

BlockingQueue 通常用于一个线程生产对象,而另外一个线程消费这些对象的场景。下图是对这个原理的阐述:

32830
来自专栏软件开发

前端MVC Vue2学习总结(七)——ES6与Module模块化、Vue-cli脚手架搭建、开发、发布项目与综合示例

使用vue-cli可以规范项目,提高开发效率,但是使用vue-cli时需要一些ECMAScript6的知识,特别是ES6中的模块管理内容,本章先介绍ES6中的基...

47070
来自专栏GopherCoder

『Go 内置库第一季:error』

Go 中的错误处理和别的语言不一样,设计哲学也不一样,常有开发者埋怨 Go 语言中的错误处理。

12330
来自专栏JackieZheng

探秘Tomcat——一个简易的Servlet容器

即便再简陋的服务器也是服务器,今天就来循着书本的第二章来看看如何实现一个servlet容器。 背景知识   既然说到servlet容器这个名词,我们首先要了解它...

24050
来自专栏跟着阿笨一起玩NET

C# 解析js方法,并调用js方法

本文转载:http://www.cnblogs.com/StudyLife/archive/2013/03/11/2953516.html

55230
来自专栏DOTNET

学会WCF之试错法——客户端调用基础

1当客户端调用未返回结果时,服务不可用(网络连接中断,服务关闭,服务崩溃等) 客户端抛出异常 异常类型:CommunicationException Inne...

28680
来自专栏cnblogs

knockoutjs 上自己实现的flux

在knockoutjs 上实现 Flux 单向数据流 状态机,主要解决多个组件之间对数据的耦合问题。 一、其实简单 flux的设计理念和实现方案,很大程度上人借...

24980

扫码关注云+社区

领取腾讯云代金券