自定义Xcode工程模版与文件模版

一、前序

不管你是新手还是老鸟,开发中都要创建项目和创建文件,例如:

创建工程 ->选择模版 ->新建项目

新建项目.png

打开工程,新建文件

新建文件.png

每次都要从一个空项目或者空文件开始,自己总结的一些公用方法都要每一次的拷贝进工程,这样的反反复复做同样的事情对于程序员来说是煎熬的,所以就有了自定义工程模版和自定义文件模版的方法(当然也可以把一些公用类打包成framework,但这样解决了文件模版的问题,还没有解决工程模版的问题),下面开始吧!

二、自定义工程模板

如果从头构建一个工程模版,那是很麻烦的,不过有便捷的方法,就是改系统模版:

Xcode系统模板的路径是/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/Xcode/Templates/,文件夹里面有文件模板File Templates和工程模板Project Templates,

到系统模版目录下(Project Templates -> Application),拷贝Single View Application.xctemplate文件夹到自定义模版目录,但目前自定义模版文件夹(Templates)中没有ProjectTemplates文件夹,不过我们可以自己创建一个,然后模拟系统模版目录结构,再Project Templates文件夹下的iOS文件夹中新建ZHJ_Application文件夹,并把Single View Application.xctemplate放到ZHJ_Application文件夹中,并改名为ZHJ View Application.xctemplate

Paste_Image.png

打开ZHJ View Application.xctemplate文件夹,可以看到文件夹中有4个文件:

Paste_Image.png

TemplateInfo.plist 属性模板属性设置
TemplateIcon.tiff 新建项目时候模版图标(可以不添加)
Main_iPhone.storyboard、Main_iPad.storyboard:模版中使用。

其中TemplateInfo.plist是模版的属性文件,每个模版都一个自己唯一标识,打开TemplateInfo.plist,修改key值Identifier对应的Value为com.apple.dt.unit.ZHJViewApplication,然后保存:


Paste_Image.png

这样重新打开Xcode,新建项目,发现我们自定义(改装Single View模版)的工程模版了:

Paste_Image.png

已经成功一半了,但不要忘记我们自定义工程模版的目的是什么。下一步,给工程模版中添加我们自己总结的一些常用公用类,这样便于以后新建工程的时候,不再需要手动的拷贝大量文件到新建的工程:
下面以 iOS开发~设备信息 提到的@interface UIDevice (Info)类别作为模版的文件为例说明具体如何操作:
1)在自定义模版ZHJViewApplication.xctemplate文件夹中,新建UIDeviceInfo文件夹,把UIDevice+Info.h 及 UIDevice+Info.m放入UIDeviceInfo文件夹中
2)配置TemplateInfo.plist

Paste_Image.png

添加系统库:TemplateInfo.plist添加一个新的Row

Paste_Image.png

然后打开Xcode,新建项目,模版选择ZHJViewApplication,效果如图:

Paste_Image.png

注意:TemplateInfo.plist其他配置补充

1)Ancestors:父模版,从父模版那里继承一些模板的基础属性,可以有多个父类。
系统模版Empty Application.xctemplate:


2)Concrete:设置为YES的模板才可以显示在new project的dialog中,此时这个模板不能被其他模板继承。
3)Definitions:将Nodes中定义的文件添加到项目中。
4)Description:新建工程时,模版的描述。
5)Identifier:模板的唯一标示符。
6)Kind:项目模板为Xcode.Xcode3.ProjectTemplateUnitKind,所有工程模版都是这个值。
7)Nodes:定义添加到工程模版中的文件。
8)Options:定义新建工程中的storyboard等。
工程模版到这里已经基本的介绍完了。

三、自定义文件模板

Xcode系统模板的路径是/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/Xcode/Templates/,文件夹里面有文件模板File Templates和工程模板Project Templates,如果修改UIViewController模板路径如下:

FlyElephant.png
选择UIViewController文件夹下的模板文件:


代码自定义模板:

//
//  ___FILENAME___
//  ___PROJECTNAME___
//
//  Created by ___FULLUSERNAME___ on ___DATE___.
//___COPYRIGHT___
//

#import "___FILEBASENAME___.h"

@interface ___FILEBASENAMEASIDENTIFIER___ ()

@end

@implementation ___FILEBASENAMEASIDENTIFIER___

#pragma mark - LifeCycle

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
}

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
}

- (void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark - Public

#pragma mark - Private

#pragma mark - Accessors

#pragma mark - Request

@end

新建控制器:


创建完成之后模板:

//
//  FEViewController.m
//  DynamicDemo
//
//  Created by keso on 2017/4/22.
//  Copyright © 2017年 FlyElephant. All rights reserved.
//

#import "FEViewController.h"

@interface FEViewController ()

@end

@implementation FEViewController

#pragma mark - LifeCycle

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
}

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
}

- (void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark - Public

#pragma mark - Private

#pragma mark - Accessors

#pragma mark - Request

@end

同时可以自定义设置模板,在文件模板下新建自定义文件夹,然后将Cocoa Touch Class.xctemplate拷贝进入新建文件下:



创建工程文件



结束语

到这里就结束了,如若不懂的话可以👇留言,也可以加入群讨论
喜欢的话 记得关注、收藏、点赞哟

群号:552048526

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342