首次砍树无掉落动画

05/101 浏览攻略
需要查看掉落动画代码。
现在理解了整个流程。让我确认 gameTime 的初始化问题 — SpawnDrops 用 self.gameTime 作为 spawnTime,但首次砍树时 gameTime 可能还是 0 或很小。
但更关键的问题在于:_SyncNPCEntries 中的 nvgCreateImage 是在 renderFunc 闭包内调用的(即在渲染时而非同步时)。首次渲染时创建纹理,该帧纹理句柄可能返回 0 或加载需要一帧延迟,导致第一帧走到 fallback 色块逻辑。
不过用户说的是"没有掉落动画",意思是没有看到从上到下的飘落效果,而是直接出现在地上。这说明动画本身的帧没有被渲染出来。
让我检查 _SyncNPCEntries 在 Update 中被调用的时序。关键在于 SpawnDrops 设置了 dirty = true,但 SpawnDrops 是在 HandleKeyDown 中调用的,而 Update 中的 dirty 检查在 Update 末尾。
问题可能是:HandleKeyDown 和 HandleUpdate 的执行顺序。让我看 main.lua 中 HandleUpdate 的 dropSystem_:Update(dt) 在什么位置。
好,dropSystem_ 在地图加载回调中创建,gameTime 初始化为 0。
现在让我更仔细地分析。用户说"第一次砍树没有掉落动画,1秒后木头直接出现在地上"。
关键在于 _SyncNPCEntries 的条件:drop.state ~= STATE_PICKED and drop.state ~= STATE_WAITING。第一个掉落物 delay=0,所以 state = STATE_FALLING,应该立即被加入 NPC 列表。
但问题可能是 nvgCreateImage 首次调用时返回的纹理句柄为 0(纹理还在加载中),导致掉落物走到 fallback 色块,但可能因为绘制参数问题根本看不到。让我仔细看 fallback 逻辑… fallback 用棕色色块,应该能看到。
等等,让我重新审视用户的描述:“1秒钟后地上出现木头”。FALL_DURATION 是多少?
纹理文件存在。问题大概率是 nvgCreateImage 首次调用时纹理没有立刻可用(异步加载),第一帧返回 0,导致走到 fallback 色块但用户看起来像是"没有东西"。等纹理加载完后已经过了 FALL_DURATION,掉落物直接处于 STATE_GROUND 了。
解决办法:在 DropSystem.New 初始化时预加载纹理,而不是在首次渲染时才加载。但 nvgCreateImage 需要 vg 上下文,初始化时可能还没有。
更好的方案:在 _SyncNPCEntries 函数里(不是在闭包里),就预加载纹理。这样每次同步时就确保纹理已经 loaded。
现在理解了根本原因。nvgCreateImage 在 renderFunc 闭包内首次调用时,纹理可能需要异步加载。加载完成前(约0.5-1秒),每帧都走到 fallback 色块(22x22像素,太小难以察觉),动画帧被"跳过"。第二次砍树时 texCache 已有句柄,渲染立即成功。
修复方案:在 DropSystem.New 中预加载纹理到引擎资源缓存,并初始化 _texCache。
问题 2 — 首次砍树无掉落动画:nvgCreateImage 在 renderFunc 闭包中首次调用时,纹理数据尚未加载到内存,导致整个掉落动画期间渲染空白。等纹理就绪时动画已结束,木头"突然出现"在地上。修复:在 DropSystem.New 中通过 cache:GetResource("Image", DROP_TEXTURE) 预加载纹理到引擎资源缓存,并初始化 _texCache,确保首次 nvgCreateImage 调用时数据立即可用。
可以预览测试了。
2
2