python 生成 cocos 序列帧动画

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

散图自动生成序列帧 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 回帖 • 151 关注
  • Python

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

    554 引用 • 675 回帖
  • Cocos
    4 引用 • 6 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 旅游

    希望你我能在旅途中找到人生的下一站。

    98 引用 • 903 回帖
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 319 回帖 • 241 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 644 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    500 引用 • 1396 回帖 • 245 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 61 关注
  • Git

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

    211 引用 • 358 回帖
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 80 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 126 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 279 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 26 关注
  • 996
    13 引用 • 200 回帖 • 5 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 33 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    133 引用 • 796 回帖
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2389 回帖 • 2 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1282 回帖 • 1 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    44 引用 • 208 回帖
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1794 回帖
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    192 引用 • 1360 回帖
  • RemNote
    2 引用 • 16 回帖 • 25 关注
  • Mobi.css

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

    1 引用 • 6 回帖 • 765 关注
  • Word
    13 引用 • 41 回帖
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 365 关注
  • WiFiDog

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

    1 引用 • 7 回帖 • 612 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 143 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 367 回帖
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖