6

我正在开发一个pebble.js从 GitHub 存储库加载的项目。我基本上是在本地编写代码,推送到 GitHub,然后拉入 CloudPebble 进行构建,因为我的计算机不适合运行 SDK。CloudPebble 正确地看到了我的图像资源,但我不知道如何引用它。resources最初,直到我将子路径移动到文件夹中,它才能找到图像。这允许正确导入,但是每当我引用我的图像时,我都会在应用程序日志中得到这个:

JavaScript Error:
send@[native code]
    at load (ui/windowstack.js:2654:22)
    at load (lib/image.js:165:11)
    at load (ui/imageservice.js:85:16)
    at resolve (ui/imageservice.js:109:60)
    at ImageType (ui/simply-pebble.js:41:32)
    at lib/struct.js:161:32
    at menuItem (ui/simply-pebble.js:814:10)
    at _resolveItem (ui/menu.js:161:30)
    at _preloadItems (ui/menu.js:170:22)
    at _resolveSection (ui/menu.js:151:25)
    at section (ui/menu.js:239:23)
    at updateActivityMenu (app.js:44:18)
    at app.js:167:21
    at onreadystatechange (lib/ajax.js:109:17)

这是我的项目结构的示例:

/project/resources/images/some_image.png
/project/src/app.js
/project/appinfo.json

这是相关的位appinfo.js

    "media": [
        {
            "file": "images/some_image.png",
            "name": "MY_IMAGE",
            "type": "png"
        }
    ]

最后是相关位app.js

    var item = {
        title: data.Response.data.activity.activityName,
        subtitle: data.Response.data.activity.activityDescription,
        icon: 'MY_IMAGE' 
    };

我也尝试过直接引用icon属性的图像路径,但图像从不显示并且我得到相同的JavaScript Error. 我可以在构建日志中看到正确添加的图像:

[ 6/29] some_image.png.pbi: resources/images/some_image.png ../../app/sdk2/Pebble/tools/bitmapgen.py -> build/resources/images/some_image.png.pbi

在这一点上,我很茫然 - 任何帮助将不胜感激。

4

2 回答 2

1

尝试使用图像的路径而不是其资源 ID:

var item = {
    title: data.Response.data.activity.activityName,
    subtitle: data.Response.data.activity.activityDescription,
    icon: 'images/some_image.png' 
};

pebble.js文档表明这是内部菜单的正确方法:

var menu = new UI.Menu({
  sections: [{
    title: 'First section',
    items: [{
      title: 'First Item',
      subtitle: 'Some subtitle',
      icon: 'images/item_icon.png'
    }, {
      title: 'Second item'
    }]
  }]
});
于 2015-03-19T16:37:09.263 回答
0

Pebble SDK 2 还是 3?在 3 之前,图像资源必须预先从 PNG 转换为 PBI。Pebble 的图像文档有更多关于原始(又名 Aplite)和 Time(又名 Basalt)Pebbles 支持哪些格式的详细信息。

于 2015-03-12T01:33:49.030 回答