基于2d Tool Kit 精灵合图,动作生成工具
http://blog.csdn.net/onerain88/article/details/18563687
2d Tool Kit 是一款出色的基于unity3d 开发2d游戏的工具,提供了丰富的编辑器工具和教程,是基于unity3d开发2d游戏的不二之选。
(PS:建议在unity3d 4.3版本(Native2D)没有稳定之前或者对新技术还不是很熟悉的情况下,可以考虑继续使用2d Tool Kit)。
1. 需求
2d游戏中最重要的概念就是Sprite了,而制作一般2d游戏都离不开Sprite的序列帧,比如一般的RPG游戏的角色有 待机,行走,攻击,被击,各种技能...动作,tk2d提供的文档里介绍的是一种很酷的点击,拖拽方式就可以完成,大概流程如下:
(1)将某个角色所有动作序列帧合成tk2dSpriteCollection(根据不同需求同一个tk2dSpriteCollection可能包括多个角色,根据需求变通)
(2)创建tk2dSpriteAnimation对象,根据动作需求创建tk2dSpriteAnimationClip对象,添加至之前创建的tk2dSpriteAnimation对象中
(PS:具体操作请参考tk2d文档)
看似非常简单的操作,但是当角色和动作数量比较多的时候,这个工作就变得非常枯燥了(尤其是对于程序员...),我们仔细观察这个枯燥的工作,发现其中的工作是有规律并且重复的工作,对于程序来说,最擅长解决的问题就是有规律并且重复的工作了!
(PS:对于程序员来说,没有规律创造规律也要上!)
最后的需求定义为:通过程序解决项目中角色及其动作的生成工作!
2. 约定
当确定好需求之后,我们要和美术做一些约定,约定如下:
(1)按不同角色将角色分组目录,比如 Hero,Monster,NPC...
(2)在角色目录下,按动作再分组目录,比如 Idle,Attack,Move...
(3)在不同的动作目录下,依次存放这个动作的所有序列帧,比如 Idle0001, Idle0002...Idle0010
3. 实现
我们所需要编程解决的问题,就是完成需求中提出的手动步骤!
(这个Demo使用的资源是tk2d中的creating a sprite animation资源)
(1)将角色所有动作序列帧合成tk2dSpriteCollection
为了简单,我从tk2d中引用了两个方法,分别为创建tk2dSpriteCollection和tk2dSpriteAnimation的Prefab
(PS:由于两个方法为普通方法,并非工具方法,于是我无耻的拷贝到了我的代码之中,为了美观,我就不贴了,最后会贴出Demo下载地址)
- string heroName = "Hero";
- // 1. New Sprite Collection
- tk2dSpriteCollection sc = CreateSpriteCollection(heroName);
- // 2. Collect Sprites' Texture Params
- List<tk2dSpriteCollectionDefinition> scDefList = new List<tk2dSpriteCollectionDefinition>();
- DirectoryInfo heroDI = new DirectoryInfo(Application.dataPath + "/Hero/");
- DirectoryInfo[] animDIArr = heroDI.GetDirectories();
- foreach (DirectoryInfo animDI in animDIArr)
- {
- FileInfo[] frameFIArr = animDI.GetFiles("*.png");
- foreach (FileInfo frameFI in frameFIArr)
- {
- tk2dSpriteCollectionDefinition frameSCDef = new tk2dSpriteCollectionDefinition();
- string framePath = "Assets/" + heroName + "/" + animDI.Name +
- "/" + frameFI.Name;
- Texture2D frameTex = AssetDatabase.LoadAssetAtPath(framePath, typeof(Texture2D)) as Texture2D;
- if (frameTex == null)
- EditorUtility.DisplayDialog("Error", "Texture2D Is NULL: " + frameFI.Name, "OK");
- frameSCDef.name = frameTex.name;
- if (!CheckSpriteNameInSC(scDefList, frameTex.name))
- EditorUtility.DisplayDialog("Error", "Duplicated Frame Name: " + frameTex.name, "OK");
- // 这里是对每个序列帧属性的设置,根据需求可以自定义默认生成属性
- frameSCDef.colliderType = tk2dSpriteCollectionDefinition.ColliderType.ForceNone;
- frameSCDef.texture = frameTex;
- frameSCDef.anchor = tk2dSpriteCollectionDefinition.Anchor.LowerCenter;
- scDefList.Add(frameSCDef);
- }
- }
- sc.textureParams = scDefList.ToArray();
- // 3. Try Rebuild
- tk2dSpriteCollectionBuilder.ResetCurrentBuild();
- if (!tk2dSpriteCollectionBuilder.Rebuild(sc))
- EditorUtility.DisplayDialog("Error", "Sprite Collection Build Failed", "OK");
(2)创建tk2dSpriteAnimation对象,创建tk2dSpriteAnimationClip对象添加至tk2dSpriteAnimation对象
- // 4. Create SpriteAnimation
- sc = GetSpriteCollection(heroName);
- tk2dSpriteAnimation heroSa = CreateSpriteAnimation(heroName);
- // 5. Create Animation Clip Array
- int clipIndex = 0;
- heroSa.clips = new tk2dSpriteAnimationClip[animDIArr.Length];
- foreach (DirectoryInfo animDI in animDIArr)
- {
- string animName = animDI.Name;
- heroSa.clips[clipIndex++] = CreateSpriteAnimationClip(animName,
- animDI.GetFiles("*.png"), sc);
- }
4. 效果
生成的tk2dSpriteCollection如下
生成的tk2dSpriteAnimation如下
5. PS
这个只是一个Demo程序,功能还不是很完善,比如对于帧序列,可能需要某些序列帧播放多帧,这时我们就需要单写一种格式去描述这个Clip了!
由于2dToolKit是收费插件,附件就只上传我的代码文件了!
基于2d Tool Kit 精灵合图,动作生成工具的更多相关文章
- excel制作折线图太麻烦?试试这些折线图在线生成工具
折线图是以折线的上升或下降来表示统计数量的增减变化的统计图,叫作折线统计图.用折线的起伏表示数据的增减变化情况,不仅可以表示数量的多少,而且可以反映数据的增减变化情况.并且折线图也是目前最方便的一种统 ...
- 【转载】利用Unity自带的合图切割功能将合图切割成子图
虽然目前网上具有切割合图功能的工具不少,但大部分都是自动切割或者根据plist之类的合图文件切割的, 这种切割往往不可自己微调或者很难维调,导致效果不理想. 今天逛贴吧发现了一位网友写的切割合图插件很 ...
- compass模块----Utilities----Sprites精灵图合图
css雪碧图又叫css精灵或css sprite,是一种背景图片的拼合技术.使用css雪碧图,能够减少页面的请求数.降低图片占用的字节,以此来达到提升页面访问速度的目的.但是它也有令人诟病的地方,就是 ...
- DX11 Without DirectX SDK--04 使用DirectX Tool Kit帮助开发
回到 DirectX11--使用Windows SDK来进行开发 DirectX Tool Kit下载 DirectX Tool Kit是一个包含许多类的集合,用于为公共Windows平台编写Dire ...
- DirectX11 With Windows SDK--04 使用DirectX Tool Kit帮助开发
前言(2018/11/4) DXTK库现在已经不随Github项目提供,因为只用到了其中的键鼠类,已经过提取加入到后续的项目中 但是如果你需要配置DirectXTK到自己的项目当中,可以参考这篇博客进 ...
- Cocos2d-JS项目之三:使用合图
studio里使用合图感觉和spriteBatchNode差不多,但有不同,合图只起到在加载资源时减少IO的作用,起不到批渲染的作用.其实想想,studio本来就是用来拼UI界面的,一个上点规模的UI ...
- 基于iCamera App Kit 测试oV5640 500w分辨率 摄像头 总结
基于iCamera App Kit 测试oV5640 摄像头 总结 iCamera App Kit 下载地址 http://pan.baidu.com/s/1kUMIwB1 可以参考下载链接的说明手册 ...
- 2D Tookit (一) 精灵切割
Sprite Dicing 精灵切割 图一:原图 Diced 设置 Diced[切割]对比图 文档 http://www.2dtoolkit.com/docs/latest/advanced/sp ...
- Falcon Genome Assembly Tool Kit Manual
Falcon Falcon: a set of tools for fast aligning long reads for consensus and assembly The Falcon too ...
随机推荐
- mysql使用基础 sql语句与数据完整性(二)
二.DML:Data Manipulation Language 数据操作语言 作用:操作表中的数据的. 关键:INSERT UPDATE DELETE 注意:日期或字符串.字符要使用单引号引起来. ...
- 自己保留:data provider
<system.data> <DbProviderFactories > <add name="MySQL Data Provider" ...
- JS的十大经典算法排序
引子 有句话怎么说来着: 雷锋推倒雷峰塔,Java implements JavaScript. 当年,想凭借抱Java大腿火一把而不惜把自己名字给改了的JavaScript(原名LiveScript ...
- 标准I/O
在程序运行时,会默认为我们打开三个流:标准输入流.标准输出流.标准出错流. 标准输入流一般对应我们的键盘 标准输出流一般对应显示器 标准出错流一般也对应显示器 1.标准输入流 在标准I/O中,java ...
- 第三章:javascript: 列表
在日常生活中,人们经常使用列表:待办事项列表,购物清单,十佳榜单,最后十名榜单等.计算机也在使用列表,尤其是列表中元素保存的是太多时.当不需要一个很长的序列中查找元素,或对其进行排序时,列表显得尤为有 ...
- 第五次课堂总结x
一.知识点: 1.while语句 循环体语句: while语句里的表达式可以是任何合法的表达式,循环体则只可以表达一条语句. while的循环体语句需要能改变循环条件的真假条件. ...
- Oracle中新增表代码
create table userinfo ( id varchar2(36) primary key, username varchar2(50) not null, password varcha ...
- 【FE前端学习】第二阶段任务-基础
技能学习部分: 1.需要熟练掌握HTML标签以及CSS各个常用属性. 2.掌握CSS3 常用属性 3.掌握jquery的基本用法,对于JS基本逻辑语句需要熟练掌握 上文 [FE前端学习]第二阶段任务- ...
- ActiveRecord中andFilterWhere使用
查询数据库时 $model; if(!empty($name)) { $model->andWhere(['name'=>$name]); } 可以用andFilterWhere,自动的把 ...
- 初次使用erlang的concurrent
如果不是它骇人听闻的并行性能,几乎不会考虑去学习这么一门语言.因为它的并行,我看到的是一块用软件写出来的电路板,是的,它几乎就是把电脑变成了一个可以自由编写逻辑的芯片. 例程来自这里:http://w ...