python 生成 cocos 序列帧动画

本贴最后更新于 2252 天前,其中的信息可能已经天翻地覆

散图自动生成序列帧 anim 动画文件

配置文件:
config.txt:

{
	"path":"/Users/wangankang/Desktop/ani",
	"time":1.2,
	"wrapMode":"1",
	"speed":1,
	"sample": 60
}

序列帧散图

#!/usr/bin/env python3
# -*- coding: utf-8 -*

import os
import json

class AniTemplate:
    spriteFrame = []
    events = []
    name = ""
    duration = 1
    wrapMode = "1"
    speed = 1
    sample = 60

    def __init__(self, name, time1):
        self.name = name
        self.duration = time1

    def setWrapMode(self, wrapMode):
        self.wrapMode = wrapMode

    def setSpeed(self, speed):
        self.speed = speed

    def setSample(self, sample):
        self.sample = sample

    def obj_2_json(self):
        return {
            "__type__": "cc.AnimationClip",
            "_name": self.name,
            "_objFlags": 0,
            "_duration": self.duration,
            "sample": self.sample,
            "speed": self.speed,
            "wrapMode": self.wrapMode,
            "curveData": {
                "comps": {
                    "cc.Sprite": {
                        "spriteFrame": self.spriteFrame
                    }
                }
            },
            "events": self.events
        }



# 读取一个json文件,并且转为json对象
def fileToJson(fileName):
    file = open(fileName)
    str = file.read()
    file.close()
    return json.loads(str)

# 读取一个meta文件中的uuid
def getMetaUuid(path):
    basename = os.path.basename(path)
    meta = fileToJson(path)
    basename = basename[0:basename.rfind(".")]
    basename = basename[0:basename.rfind(".")]
    return meta['subMetas'][basename]['uuid']

def saveStrToFile(file_name, contents):
    fh = open(file_name, 'w')
    fh.write(contents)
    fh.close()


def genAnim(path, name, time,wrapMode,speed, sample, has_even):
    print("=================================")

    fileList = os.listdir(path)
    metaList = []
    for i in range(0, len(fileList)):
        if fileList[i].endswith(".meta"):
            metaList.append(fileList[i])

    metaList.sort()

    print("读取meta序列帧文件完成,共{" + str(len(metaList)) + "}个")

    if 0 == len(metaList):
        print(name + ">没有找到meta文件,无法生成序列帧,自动跳过")
        return

    # step = time / (len(metaList) - 1)
    step = 0.125
    time = 0.125 * len(metaList)

    print("序列帧动画间隔为:" + str(step) + "s")

    print("准备生成动画文件....")
    template = AniTemplate(name, time);

    template.setSample(sample)
    template.setSpeed(speed)
    template.setWrapMode(wrapMode)

    lastFrameTime = 0

    spriteFrame = []
    for i in range(0, len(metaList)):
        lastFrameTime = i*step
        spriteFrame.append({
            "frame": i * step,
            "value": {
                "__uuid__": getMetaUuid(path +"/" + metaList[i])
            }
        })

    template.spriteFrame = spriteFrame;

    if has_even:
        template.events = [{
            "frame": lastFrameTime,
            "func": "actionOver",
            "params": []
        }]
    else:
        template.events = []

    saveStrToFile(name + '.anim', json.dumps(template, default=AniTemplate.obj_2_json, sort_keys=False, indent=4))

    print("文件生成完成:\n" + os.path.realpath(name + '.anim'))

#
# =======================================
#               main
# =======================================
#

print("开始读取config配置数据...")
config = fileToJson("./config.txt")
print("读取config配置成功...")

path = config['path']
time = config['time']
# wrapMode = config['wrapMode']
speed = config['speed']
sample = config['sample']

print("配置数据解析完成")
print("\tpath:" + path)
print("\ttime:" + str(time))

root = os.listdir(path)
for i in range(0, len(root)):
    if os.path.isdir(path + "/" + root[i]):
        aniPath = path + "/" + root[i]
        aniName = root[i]
        aniName = str(aniName)
        hasAtk = aniName.find("Attack") != -1
        hasStand = aniName.find("Stand") != -1

        hasEvent = hasAtk

        wrapMode = 1
        if hasStand:
            wrapMode = 2

        genAnim(aniPath, aniName, time,wrapMode,speed, sample, hasEvent)


序列帧合集:

#!/usr/bin/env python3
# -*- coding: utf-8 -*

import os
import json

class AniTemplate:
    spriteFrame = []
    events = []
    name = ""
    duration = 1
    wrapMode = "1"
    speed = 1
    sample = 60

    def __init__(self, name, time1):
        self.name = name
        self.duration = time1

    def setWrapMode(self, wrapMode):
        self.wrapMode = wrapMode

    def setSpeed(self, speed):
        self.speed = speed

    def setSample(self, sample):
        self.sample = sample

    def obj_2_json(self):
        return {
            "__type__": "cc.AnimationClip",
            "_name": self.name,
            "_objFlags": 0,
            "_duration": self.duration,
            "sample": self.sample,
            "speed": self.speed,
            "wrapMode": self.wrapMode,
            "curveData": {
                "comps": {
                    "cc.Sprite": {
                        "spriteFrame": self.spriteFrame
                    }
                }
            },
            "events": self.events
        }



# 读取一个json文件,并且转为json对象
def fileToJson(fileName):
    file = open(fileName)
    str = file.read()
    file.close()
    return json.loads(str)

# 读取一个meta文件中的uuid
def getMetaUuid(path):
    basename = os.path.basename(path)
    meta = fileToJson(path)
    basename = basename[0:basename.rfind(".")]
    basename = basename[0:basename.rfind(".")]
    return meta['subMetas'][basename]['uuid']


def get_plist_uuid(path):
    basename = os.path.basename(path);
    json = fileToJson(path)
    sub_metas = json['subMetas']

    key_list = [];

    for key in sub_metas:
        key_list.append(key)

    # 自定义排序 0.png => int("0.png".sub(0,xxx.indexOf("."))) => int("0)
    key_list.sort(key=lambda i: int(i[0:i.rfind(".")]), reverse=False)


    uuid_list = []
    for i in range(0, len(key_list)):
        uuid = json['subMetas'][key_list[i]]['uuid']
        uuid_list.append(uuid)
    return uuid_list;

def saveStrToFile(file_name, contents):
    fh = open(file_name, 'w')
    fh.write(contents)
    fh.close()

def genAnim(path, name, time,wrapMode,speed, sample, has_even):
    print("=================================")

    fileList = os.listdir(path)
    metaList = []
    for i in range(0, len(fileList)):
        if fileList[i].endswith(".plist.meta"):
            metaList.append(fileList[i])

    metaList.sort()

    print("读取当前文件夹meta plist文件完成,共{" + str(len(metaList)) + "}个plist")

    # 获取plist 里面的所有uuid
    uuid_list = get_plist_uuid(path +"/" + metaList[0])

    if 0 == len(metaList):
        print(name + ">没有找到meta文件,无法生成序列帧,自动跳过")
        return

    if 0 == len(uuid_list):
        print(name + ">没有找到plist下的uuid, 无法生成序列帧动画,自动跳过")
        return

    # step = time / (len(metaList) - 1)
    step = 0.125
    # time = 0.125 * len(metaList)
    time = 0.125 * len(uuid_list)

    print("序列帧动画间隔为:" + str(step) + "s")

    print("准备生成动画文件....")
    template = AniTemplate(name, time);

    template.setSample(sample)
    template.setSpeed(speed)
    template.setWrapMode(wrapMode)

    lastFrameTime = 0

    spriteFrame = []
    for i in range(0, len(uuid_list)):
        lastFrameTime = i*step
        spriteFrame.append({
            "frame": i * step,
            "value": {
                # "__uuid__": getMetaUuid(path +"/" + metaList[i])
                "__uuid__": uuid_list[i]
            }
        })

    template.spriteFrame = spriteFrame;

    if has_even:
        template.events = [{
            "frame": lastFrameTime,
            "func": "actionOver",
            "params": []
        }]
    else:
        template.events = []

    saveStrToFile(name + '.anim', json.dumps(template, default=AniTemplate.obj_2_json, sort_keys=False, indent=4))

    print("文件生成完成:\n" + os.path.realpath(name + '.anim'))

#
# =======================================
#               main
# =======================================
#

print("开始读取config配置数据...")
config = fileToJson("./config.txt")
print("读取config配置成功...")

path = config['path']
time = config['time']
# wrapMode = config['wrapMode']
speed = config['speed']
sample = config['sample']

print("配置数据解析完成")
print("\tpath:" + path)
print("\ttime:" + str(time))

root = os.listdir(path)
for i in range(0, len(root)):
    if os.path.isdir(path + "/" + root[i]):
        aniPath = path + "/" + root[i]
        aniName = root[i]
        aniName = str(aniName)
        hasAtk = aniName.find("Attack") != -1
        hasStand = aniName.find("Stand") != -1

        hasEvent = hasAtk

        wrapMode = 1
        if hasStand:
            wrapMode = 2

        genAnim(aniPath, aniName, time,wrapMode,speed, sample, hasEvent)




  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 177 关注
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    548 引用 • 674 回帖
  • Cocos
    4 引用 • 6 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 30 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖
  • OneDrive
    2 引用 • 3 关注
  • Excel
    31 引用 • 28 回帖
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 407 回帖 • 485 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 753 关注
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 1 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    170 引用 • 513 回帖
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖 • 2 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 2 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 207 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖 • 2 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 177 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 437 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 30 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • 印象笔记
    3 引用 • 16 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 600 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    179 引用 • 996 回帖
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 72 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 780 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖