经过一番周折,终于在xcode5上实现了一个简单的自定义模板,在项目中集成NSLogger库(增强NSLog的功能,https://github.com/fpillet/NSLogger)——新建项目中自动加入LoggerClient.h,LoggerClient.m ,LoggerCommon.h以及一些Frameworks。

  如果从零开始定义一个模板,未免太过复杂,最简单的方法就是把系统模板复制过来修改^_^。

  系统模板路径:

//路径1
Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/Xcode/Templates
//路径2
Xcode.app/Contents/Developer/Library/Xcode/Templates

  可以看到,两个路径下的模板都分为File Templates和Project Templates两种。顾名思义,文件模板用于创建文件,项目模板用于创建项目,这里需要的是Project Templates。这里在Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/Xcode/Templates/Project Templates/下找到Single View Application.xctemplate模板,复制到自定义模板路径下。

  自定义模板的存放位置:

~/Library/Developer/Xcode/Templates

  如果之前安装过cocos2d,那么在上面路径下就可以看到cocos2d的库文件。借鉴cocos2d和PhoneGap的做法,把Single View Application.xctemplate放在路径3下:

//路径3
~/Library/Developer/Xcode/Templates/Project Templates/Application

  然后需要两步:

    --把Single View Application.xctemplate文件夹名称改为xxx.xctemplate,后缀名必须为xctemplate,这里以Test Template.xctemplate为例。

    --打开Test Template.xctemplate中的TemplateInfo.plist文件,将键Identifier的值改为com.apple.dt.unit.testTemplateApplication,这个值是模板的唯一标识。

保存更改后,在new project的templates dialog中就可以看到刚刚定义的模板了:

此时Test Template模板与系统的Single View Application模板是一样,要想进行自定义,我们先来分析下Test Template.xctemplate的组成。

    --TemplateInfo.plist(必要):所有的模板属性设置都在这里。

    --TemplateIcon.tiff(可选):定义显示在new project的dialog中的模板图标。

    -- Main_iPhone.storyboard、Main_iPad.storyboard:要添加在项目中的文件。

  所以这里我们把NSLogger的库文件放到Test Template.xctemplate下:

此时新建Test Template项目,肯定是不会自动添加上NSLogger文件的,看来还需要在TemplateInfo.plist中设置一番。

打开TemplateInfo.plist,先来分析一下各个键值的意义:

  Ancestors:要继承的模板。也就是模板的“父类”,从父类那里继承一些模板的基础属性,可以有多个父类。

  Concrete:设置为YES的模板才可以显示在new project的dialog中,此时这个模板不能被其他模板继承。

  Definitions:将Nodes中定义的文件添加到项目中(还有其他功能,这里暂且不表)。

  Description:就是Description。

  Identifier:刚才已经接触过,模板的唯一标示符,若模板B要继承模板A,就在模板B的Ancestors中写上模板A的Identifier。

  Kind:项目模板为Xcode.Xcode3.ProjectTemplateUnitKind,文件模板为Xcode.IDEKit.TextSubstitutionFileTemplateKind。

  Nodes:定义要添加到项目中的文件(还有其他功能,这里暂且不表)。

  Options:定义在new project中选择模板后点击next后的dialog中的内容,如Product Name、Organization Name、Company Identifier、Bundle Identifier等。

  SortOrder:该模板显示在new project的dialog中的位置索引。

更详细的解释会在后面给出链接。

回头看下我们的需求:在新建项目中自动加入LoggerClient.h,LoggerClient.m ,LoggerCommon.h以及一些Frameworks。那么首先编辑的键值就是Nodes、Definitions。    

  Nodes编辑如下:

Definitions编辑如下:

需要注意的是这里LoggerClient.h,LoggerClient.m ,LoggerCommon.h三个文件都是放在NSLogger文件夹下的。

保存plist修改,此时新建Test Template项目,可以看到已经自动添加上了NSLogger类了。

还有一步工作,需要在项目中添加上NSLogger库要求的Frameworks。很简单,在plist中加入一个key ——Targets。

保存plist后,新建Test Template项目,完工。附上TemplateInfo.plist以供参考。

最后附上参考资料:http://www.learn-cocos2d.com/store/xcode4-template-documentation/里面详细的介绍文件模板和项目模板(Xcode4的方法适用与xcode5),以及TemplateInfo.plist中各个键值的意义。感谢这篇文章的作者。

xcode5 自定义模板的更多相关文章

  1. Django自定义模板

    定义simple_tag步骤 一.创建templatetags文件 首先在app下创建templatetags文件:名字不许叫这个,不能改变. 二.在文件中创建一个py文件 文件名自定义 三.在创建的 ...

  2. 学习CodeIgniter框架之旅(一)自定义模板目录

    在常用的框架本身都已经做好了分层和目录结构,但这在很多时候不满足项目的需求甚至在某些情况下变得不合理,因此很多时候需要自定义目录结构,在此就看看如果在CodeIgniter框架中自定义模板目录: 在C ...

  3. .NET/ASP.NETMVC 深入剖析 Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(三)

    阅读目录: 7.HtmlHelper.HtmlHelper<T>中的ViewModel的类型推断 8.控制ViewModel中的某个属性的呈现(使用PartialView部分视图细粒度控制 ...

  4. 使用requireJS,backboneJS,和underscoreJS完成自定义模板封装

    使用requireJS,backboneJS,和underscoreJS完成自定义模板封装 原来的代码 当我们进行一个列表的数据填充的时候,是这样做的: //获取美食列表 function getFo ...

  5. DISCUZ 自定义模板

    DISCUZ 自定义模板 模板安装和维护 安装新模板 将模板template打包放在对应目录:template/ 后台 -> 界面 -> 风格管理 , 安装模板 后台 -> 界面 - ...

  6. 谈谈yii2-gii如何自定义模板

    作者:白狼 出处:http://www.manks.top/article/yii2_gii_custom_template本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位 ...

  7. SharePoint 2013 自定义模板页后在列表里修改不了视图

    前言 最近系统从2010升级至2013,有自定义模板页.突然发现在列表中切换不了视图,让我很费解. 我尝试过以下解决方案: 去掉自定义css 去掉自定义js 禁用所有自定义功能 结果都没有效还是一样的 ...

  8. WPF Step By Step 自定义模板

    WPF Step By Step 自定义模板 回顾 上一篇,我们简单介绍了几个基本的控件,本节我们将讲解每个控件的样式的自定义和数据模板的自定义,我们会结合项目中的具体的要求和场景来分析,给出我们实现 ...

  9. SublimeText插件Emmet的自定义模板

    在前端界,作为快速生成代码的Emmet插件相当给力.最近在学bootstrap,需要频繁生成html头文件,我就想着自定义模板.国内只有基础教程,只好自己读英文文档了. Emmet国内基础教程地址: ...

随机推荐

  1. Hibernate学习笔记(一):级联删除

    一对多的关系映射 在一的一方配置文件中将会配置set节点信息: *.hbm.xml配置文件中set节点的属性: Lazy:默认是true 即使用延迟加载,false表示即时加载: Order-by:一 ...

  2. MongoDB 聚合

    聚合操作过程中的数据记录和计算结果返回.聚合操作分组值从多个文档,并可以执行各种操作,分组数据返回单个结果.在SQL COUNT(*)和group by 相当于MongoDB的聚集. aggregat ...

  3. S3C2440 I2C总线控制

    概述:话不多说,直接上图 多主机IIC总线控制(IICCON): IIC控制总线状态(IICSTAT): IIC总线地址(IICADD): IIC发送,接收总线寄存器(IICDS) IIC总线控制寄存 ...

  4. STL——临时对象的产生与运用

    所谓临时对象,就是一种无名对象.它的出现如果不在程序员的预期之下(例如任何pass by value操作都会引发copy操作,于是形成一个临时对象),往往造成效率上的负担.但有时候刻意制造一些临时对象 ...

  5. git使用介绍

    Git简单介绍 参考网址: git使用简介 这个教程推荐使用:git教程 git和svn的差异 git和svn的最大差异在于git是分布式的管理方式而svn是集中式的管理方式.如果不习惯用代码管理工具 ...

  6. Python多进程使用

    [Python之旅]第六篇(六):Python多进程使用   香飘叶子 2016-05-10 10:57:50 浏览190 评论0 python 多进程 多进程通信 摘要:   关于进程与线程的对比, ...

  7. Oracle 安装中遇到的问题

    第一次用甲骨文,这期待!虽然mySQL也是甲骨文的. 去官网下了Oracle G11 R2 X64,本人的电脑是64位的win7,没开防火墙. 按照网上众多的教程,做完安装,可是安装过程不是那么的顺利 ...

  8. ie下面兼容性问题的一些总结

    最后一次搞ie兼容性问题,以后都可以不管了0.0 1.浮动兼容性 1.1IE6下的双边距BUG 在IE6下,块元素有浮动和横向margin的时候,最边上元素的横向margin值会被放大成两倍 解决办法 ...

  9. 关于uploadify 没有显示进度条!!!!

    如果你也弄了很久不知道为什么不出现上传进度条!,那就一定要看这里了! 我注释了 queueID 属性后 就出现了!!!!! 就是这么简答! //添加界面的附件管理 $('#file_upload'). ...

  10. JqueryAjax

    1. 2. 3. 4. 5. 6. 7.