fenix3吧 关注:8,656贴子:38,185

Garmin开发-布局

只看楼主收藏回复

上一章节介绍了garmin app开发的入门,包括garmin-sdk,开发工具的安装部署,文章结尾我们新建了我们的第一个app程序
Garmin开发-入门: http://tieba.baidu.com/p/4325635755?pid=83103366105&cid=0#83103366105
这一章我们主要讲fenix3 的布局
文件层次,内容介绍
先来看看整个项目的架构,层次

bin:编译后的文件,编译后直接拷入garmin/app就可以使用了,具体后面讲
resources:资源文件
drawables:预绘制图像文件(也可以叫局部布局)可以搭配layout文件使用
layouts:布局文件,主要放一些初始化布局资源,文字,图片等等
strings:字符串资源文件,可以预设一些字符串,可以在用的时候通过id获取
在resources文件下还可以建立一些自己的文件,比如fonts,images等资源文件
source:编译文件,通常说的逻辑主体,以.mc文件后缀结尾
manifest.xml:配置文件可以,看成.net的config文件
布局文件:layout.xml

讲布局文件之前先将几个知识点:
查看api文档方法:在我们下载的sdk的doc下面,或者直接点击

1:颜色和字体都在这个模块下

对应相应的字体和颜色常量
回来讲layout.xml中id为资源中的唯一id,背景色为布局的背景色
drawabel相当于调用了个id为background 的外部的画布一样,这个画布资源放在drawables文件夹下,暂时取名为background.xml
label为文字
属性包括字体,颜色,坐标,文字信息,对其方式
我们再看看上面说的background.xml怎么定义的,如图

drawable-list:画布列表,id唯一标示,因为是呈现的是局部画布,所以有坐标x,y,foreground主体颜色
shape:形状
type为形状类型
circle圆,radius半径,
polygon多边形,pot(多边形)ions为二位数组(一剂)
拥有这些就可以造出我们喜欢的形状
再来看字符串资源文件strings.xml

这个很简单,id对应相应的字符串,取值的时候用@strings.id 名 就可以了
font.xml 字体文件
<font id="font_id" filename="/path" />
依然获取字体时@fonts.id名
bitmaps.xml 图像资源

取值用@Drawables.id名
当编译器编译的时候都讲整理到一个文件,所以看自己的喜好排版相应的文件都可以
再看配置文件manifest.xml

这个文件主要是已type app类型(watchface,app,datafield,widget)
设备类型: <iq:products>
访问模块权限<iq:permissions>
这些可以用工具配置,项目右键>属性

部分模块需要配置权限在能访问
当然不是每个模块都能被所有应用访问的,具体权限可以看官方文档

布局
以上介绍了各个文件之间的关系和用法,下面来看一下具体的布局界面
Fenix的桌面布局把他看成一个坐标轴图

fenix3的分辨率为218*218,Fenix中心为坐标(109,109),把圆圈看成是fenix3可视区域,坐标关系如上图,很容易懂吧
表盘中心为x=109,y=109,其他各个点的坐标一目了然了
看看具体的效果,中心实心圆


无规则多边形


拥有这些就可以做出自己想要的效果了,比如五角心,三角形椭圆,指针等等,除了在资源文件里布局画出这些图案外,还可以在逻辑程序里也就是.mc文件里用dc画,将更加灵活方便.
布局就为大家讲到这里,当然还有很多二米讲到的细节问题,这只有个大概,关于细节问题不懂的,可以一起讨论
下一篇讲解逻辑程序和api的实际使用


IP属地:北京1楼2016-03-01 18:12回复
    好贴,必须顶


    IP属地:山东来自iPhone客户端2楼2016-03-01 20:06
    回复
      顶顶顶


      IP属地:北京3楼2016-03-02 09:35
      回复
        顶顶顶


        IP属地:北京4楼2016-03-02 14:50
        回复
          希望快点更新,让更多的人学会!上次的教程看完还是云里雾里这次也差不多,数据调用才是关健


          IP属地:广东5楼2016-03-03 13:57
          收起回复
            楼主适当放出一两个实例来下载这样更加事办利于我们研究和发现


            IP属地:广东6楼2016-03-03 14:01
            收起回复
              来学习!


              IP属地:辽宁7楼2016-03-22 13:53
              回复
                java没学会,只能看楼主的


                IP属地:山西8楼2016-03-24 18:56
                回复
                  怒学jave


                  IP属地:浙江来自iPhone客户端9楼2016-03-31 21:46
                  回复
                    学习了


                    IP属地:安徽10楼2016-03-31 21:48
                    回复
                      技术帖,强烈支持一下


                      IP属地:广东11楼2016-04-13 11:19
                      回复
                        下一篇呢?求链接
                        还有一个问题,写fenix 3的app,没有用到java吗?全部都是html和js?


                        12楼2016-06-17 20:05
                        收起回复
                          顶楼主,牛人。


                          13楼2016-07-07 11:03
                          收起回复
                            楼主有交流群吗?或者你的联系方式,交流一下啊,官方文档 看的我云里雾里的


                            IP属地:北京14楼2016-07-15 14:08
                            回复
                              天书啊


                              IP属地:内蒙古来自Android客户端15楼2016-07-15 19:47
                              回复