当前位置:  编程技术>移动开发
本页文章导读:
    ▪彩信SMIL资料解析        彩信SMIL文件解析 SMIL是同步多媒体集成语言(Synchronized Multimedia Integration Language)的缩写,念做smile.它是由W3C(World Wide Web Consortium)组织规定的多媒体操纵语言。最新的SMIL版本是2001年8月推出.........
    ▪ 翻页成效        翻页效果 显示sd卡中txt文件。 ......
    ▪ 应用程序签字       应用程序签名 这篇文章将阐述在应用程序发布前有关应用程序签名的内容。 概述 Android系统要求,所有的程序经过数字签名后才能安装。Android系统使用这个证书来识别应用程序的作者,并.........

[1]彩信SMIL资料解析
    来源: 互联网  发布时间: 2014-02-18
彩信SMIL文件解析
SMIL是同步多媒体集成语言(Synchronized Multimedia Integration Language)的缩写,念做smile.它是由W3C(World Wide Web Consortium)组织规定的多媒体操纵语言。最新的SMIL版本是2001年8月推出的SMIL 2.0版本(参与制定该标准的公司奇多,J 有Compaq、Gateway、IBM、Microsoft、RealNetworks、Oratrix等等。)。SMIL与我们网页上用的HTML的语法格式非常相似。后者主要针对普通的网络媒体文件进行操纵(文字、图片、声音、动画、视频的机械堆砌),而前者则操纵多媒体片断(对多媒体片断的有机的、智能的组合)。

目录

SMIL基本知识
SMIL详细解析
SMIL的优点
bk.view.catalog().start("0");
SMIL基本知识
  下面我们看一个实际的SMIL的例子(用记事本编写就可以,注意:在英文状态下编辑。也就是不要打开中文输入法。因为SMIL播放器不认识中文的标点符号!):
  程序代码
  < smil>
  < head>
  < meta. name="copyright" content="Your Name" />
  < layout>
  < !-- layout 标记 -->
  < /layout>
  < /head>
  < body>
  < !—媒体标记 -->
  < img src="/blog_article/image1.jpg"/>
  < /body>
  < /smil>
  显然,SMIL和HTML语言的语法格式非常相像!所以,如果大家对HTML熟悉的话,SMIL学习起来就很容易。但是,二者的差别是很大的,所以如果想学的很好,大家一定要认真地学!
  从上面这个例子可以看出:
  (1) SMIL程序以<smil>开始,以</smil>结束。
  SMIL必须以<smil>开始,以</smil>结束,其他的一切标记都在这二者之间。这个和HTML好像是一样的。
  (2) 整个程序由body和head两个部分组成
  其中body是必须要有的。而head部分则看实际情况。如果需要的话,我们就写。若是整个SMIL程序非常简单并且没有必要用head部分,那么,我们可以不写。从个人的经验来看,如果要写出一个效果好的演示,head部分是必不可少的!
  (3) 属性和标记要求小写
  SMIL要求其标记和标记的属性必须小写!
  我们在这里不想给出属性和标记的定义。SMIL语言就是由标记组成的。每一行都是标记,而标记基本上都有属性。例如:< img src="/blog_article/image1.jpg"/>中,img是标记,而src是属性,image1.jpg是src的属性值。注意:属性值可以大小写都可以。后面我们会碰到有些属性值要求骆驼写法。什么是骆驼写法?像fadeTocolor这样的属性值(看看,中间高,两边低,是不是非常像骆驼的驼峰?)就是骆驼写法。
  (4) 有些标记必须有一斜杠作为结束标记
  在SMIL中,如果标记不是配对标记(例如:< smil>< /smil>、< head>< /head>、< body>< /body>等),那么,必须有一斜杠作为结束标记(例如:< img src="/blog_article/image1.jpg"/>)。
  (5) 属性值必须用双引号括起来
  例如:src="/blog_article/image1.jpg"。注意:SMIL文件中出现的文件名必须和服务器上的文件名一致,其路径一定要正确。否则,SMIL播放器找不到该文件。
  (6) SMIL文件的拓展名为*.smil或者*.smi
  我们必须以*.smil或者*.smi的拓展名来保存SMIL文件。这样SMIL播放器才能认出SMIL文件,以采用正确的解码方式解码、播放。为了防止与其它类型文件的拓展名冲突,强烈建议采用*.smil这个拓展名!注意:文件名必须是以数字、字母开始的,中间可以有下划线,不可以有空格。例如:test_one.smil可以,而test one.smil坚决不行!如果你喜欢的话,可以用我们上面讲的骆驼写法testOne.smil。注意:上面的例子大家可以原版复制,保存为testOne.smil。并且找一个图片放到testOne.smil同一个文件夹下,并将image1.jpg改成你的图片的名字(后面如果没有特殊说明,都得这么做),就可以用Realone player打开该源程序,看看我们的第一个演示的效果了。
  (7) 附加信息写在< head>< /head>之间
  如果我们有些关于源代码的一些说明也就是附加信息,例如版权、作者、标题、基地址等等,我们可以在< head>< /head>中说明。其基本的格式是:< meta. name=" " content=" " />,例如:
  程序代码
  < meta. name="author " content="litterone " />
  < meta. name="title " content="I want to learn SMI:L " />
  (8) 用< !-- … -->进行注释
  这个标记和HTML里面的是一样的。我们可以对我们的源文件进行注释。SMIL播放器遇到这个标记后,将跳过去而不予理睬。例如:我们可以在写源代码以前,将我们想要实现的效果在< !-- … -->中写出来,然后在编写源代码,假如我们忘记了删除该段说明,也不会影响演示的执行。
  上面简单介绍了SMIL语言的基本知识,接下来要详详细细地学习SMIL!
SMIL详细解析
  SMIL语言的内容很多,我们从最常用的开始谈起。(准备好了吗?上路了!)
  1、 多媒体片断结构组织(1)< seq>< /seq>标记我们首先看下面这个例子:
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < seq>
  < img src="/blog_article/image1.jpg"/>
  < img src="/blog_article/image2.jpg"/>
  < /seq>
  < /body>
  < /smil>
  请保存(记得要用*.smil这样的文件格式 J)并运行该源程序看看效果。我相信如果大家看到的是这样的效果:Realone player先显示image1.jpg,然后显示image2.jpg。这就是我们这里用< seq>< /seq>这对顺序播放标记规定的结果。< seq>< /seq>规定的是:在< seq>< /seq>中间的多媒体片断顺序播放。如下图所示。
  (2) < /par>标记
  接下来瞧瞧这个例子:
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < par>
  < img src="/blog_article/image1.jpg"/>
  < img src="/blog_article/image2.jpg"/>
  < /par>
  < /body>
  < /smil>
  保存->运行->看效果。Realone player同时显示image1.jpg和image2.jpg。这就是我们这里用< par>< /par>这对并行播放标记所得到的结果。< par>< /par>规定的是:在< par>< /par>中间的多媒体片断并行播放。如下图所示。
  (3)< seq>< /seq>和< par>< /par>标记协同使用分析下面这个例子:
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < seq>
  < img src="/blog_article/image1.jpg"/>
  < par>
  < img src="/blog_article/image2.jpg"/>
  < img src="/blog_article/image3.jpg"/>
  < /par>
  < img src="/blog_article/image4.jpg"/>
  < /seq>
  < /body>
  < /smil>
  这个例子的效果是这样的:Realone player先显示image1.jpg,接下来同时显示image2.jpg和image3.jpg, 然后显示image4.jpg。为什么会这样?其中原因我想大家一定非常清楚了。我就不啰嗦了。
  有了< seq>< /seq>和< par>< /par>这样两对标记后,我们对多媒体片断播放的先后顺序的控制就变得非常方便了。但是,我们上面的这些演示虽说是演示了。但是,它们的显示时间好像没有受到我们的控制。接下来着手解决这个问题。
  2、 时间控制
  (1)dur属性
  请大家看看下面这段代码的效果。
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < seq>
  < img src="/blog_article/image1.jpg" dur="5s"/>
  < img src="/blog_article/image2.jpg" dur="10s"/ >
  < /seq>
  < /body>
  < /smil>
  相信大家已经看出门道了!对了,我们这里对image1.jpg和image2.jpg的持续时间做了规定。其中image1.jpg持续时间5秒,image2.jpg持续时间10秒。
  (2)begin和end属性
  上面规定的是播放多长时间,我们也想规定在什么时候开始播放。请看下面的程序。
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < img src="/blog_article/image1.jpg" begin="2" dur="5s"/>
  < /body>
  < /smil>
  上面的这段程序规定就是图片image1.jpg在整个演示进行2秒后,开始显示,持续的时间是5秒。对于图片的控制是这样,而我们常常需要对视频/音频的时间进行控制。下面这个例子来说明这个问题。
  程序代码
  < smil>
  < head>
  < /head>
  < body>
  < video src="/blog_article/test.rm" begin="5s" end="40s"/>
  < /body>
  < /smil>
  test.rm这个视频文件(如果大家手头上没有*.rm格式文件,就用Realone player的firstrun.rm或者找个*.avi的也可以。但是文件名要写对!)在整个演示开始5秒后开始播放,在整个演示播放40秒以后,就结束播放。实际的播放时间是:40-5=35秒。但是,一般情形下,我们的视频总在一个组中,这时候,他就的服从组的时间了。我们那下面的这个例子来解释这问题。
  程序代码
  < smil>
  < body>
  < seq dur="5">
  < img src="/blog_article/image1.jpg" begin="2" dur="10"/>
  < /seq>
  < /body>
  < /smil>
  image1.jpg所在的组的持续时间为5秒,而image1.jpg自己要求持续10秒,这是不行的。实际上image1.jpg的显示时间只有5-2=3秒!大家在以后写程序的时候要注意这个问题。
  (3)clip-begin和clip-end属性
  考虑这样一种效果:
  我们只要test.rm播放这个视频/音频的5~10秒这个时间断,怎么办???J有了clip-begin和clip-end,问题就很简单了!请看:
  程序代码
  < smil> < body>< video src="/blog_article/test.rm" clip-begin="5s" clip-end="10s"/> < /body>< /smil>
  clip-begin和clip-end属性是用内部时间控制的属性。这里的内部指的就是多媒体片断自己的时间线(timeline)。前者规定在什么地方开始播放,后者规定放到什么地方结束播放。为了更清楚的理解这些时间控制,我们看下面的这个例子:
  程序代码
  < smil>
  < body>
  < par>
  < audio src="/blog_article/testone.rm" clip-begin="5" dur="10s"/>
  < audio src="/blog_article/testtwo.rm" begin="7s" clip-begin="2s"clip-end="15s"/>
  < /par>
  < /body>
  < /smil>
  看看下面这个示意图: 显然,首先是testone.rm从自己的5秒处开始播放,播放7秒以后,testtwo.rm从自己的2秒处开始与testone.rm一起播放,testone.rm播放到自己得15秒处停止播放,testone.rm播放了15-5=10秒。testtwo.rm播放到自己得15秒处停止播放,testone.rm播放了15-2=13秒。图中灰色(黄色)部分表示播放的部分。
  接下来我们对时间的表示方法做个说明(默认的时间是秒,所以"2s" 、"2.0s"和"2"都是一样的 ):
  时间标记 指代 例子 说明
  h 小时 1.5h 1小时30分钟
  min 分钟 4.75min 4分45秒
  s 秒 10.45 10秒450毫秒
  正确的时间写法是: hh:mm:ss.xy。hh表示小时;mm表示分钟;ss表示秒;x表示1/10秒;y表示1/100秒。例如:begin="01:40.0"表示的是1分40秒处开始,而begin="01:40"表示的是1小时40分处开始。真的注意呀J。
  时间控制非常重要,它直接影响我们演示的效果。而我们上面讲的这部分是最重要的,所以大家一定要理解上面的各个时间概念及其含义。
  (4)fill属性
  当演示中的某个片断播放完成以后,我们可以用fill属性来规定它的显示状态。简单的说就是我们是清屏还是冻结屏幕。看下面这个例子:
  程序代码
  < smil>
  < body>
  < video src="/blog_article/test.rm" dur="30s" fill="freeze"/>
  < /body>
  < /smil>
  假设test.rm的长度是20秒,那么我们这里规定的就是:在test.rm播放终了以后,屏幕上显示的是test.rm的最后一帧(通俗的说就是最后一幅画面),显示的时间是30-20=10秒;如果是图片的话,那么显示就是图片。
  Fill属性只有remove和freeze两个,默认的值为remove。建议大家在演示的最后的一个多媒体片断上用冻结(freeze),以防止屏幕上空空如也!J
  (5)repeat属性
  如果我们希望我们演示中的某个片断或者全部的片断重复播放若干次(姑且设为2次)。那么我们可以后用repeat属性来实现该效果。分析下面这个例子:
  程序代码
  < smil>
  < body>
  < vedio src="/blog_article/test.rm" dur="1min" repeat="2"/>
  < /body>
  < /smil>
  上面这个例子就是让test.rm播放两次。如果我们想让某个片断一直播放下去(网络光广告上可以考虑这个),那么repeat="indefinite"就可以了。当然,想要它停下来的一种方法是按下播放器stop(停止)键(在网页插件中就是右键菜单中的stop);另外的一种办法(大家都知道的)是关闭计算机!J
  3、 布局设计
  我们这里所说的布局就是在我们的屏幕上定出各个多媒体片断显示的位置(单纯的声音文件是不需要布局的!为什么?J 因为我们的耳朵听不出声音在屏幕上的什么地方;而我们的眼睛可以看到图片、动画和文字在什么地方!),准确地说是在播放器中。从前面我们并行播放的例子可以看出来,如果我们不对布局进行设计,那么显示的效果一塌糊涂!这里是SMIL的重点和精华部分之一,打起精神,Let’s go!
  (1) 定义基本显示窗口
  看下面的代码:
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="300" height="200" background-color="white" />
  < /layout>
  < /head>
  < body>
  < /body>
  < /smil>
  说明:a、 布局标记必须以< layout>开头,以< /layout>结束,其他具体的标记都在这中间。< layout>< /layout>必须放在< head>< /head>之间。
  b、 root-layout标记表明的是规定最基本的、最底层的窗口。其他一切窗口都在它的基础上划分出来。
  c、 width="300" 表明窗口宽为300个像素点;height="200"表明窗口高为200个像素点;background-color="black"表明窗口的背景颜色为黑色。这里也可以用颜色代码。例如:background-color="#000000"。个人更喜欢代码,因为颜色代码表达颜色众多,但是代码不直观。
  (2) 定义多媒体片断显示窗口
  分析下面这段源程序:
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="300" height="300" background-color="yellow" />
  < region id="vedio_region" left="5" top="5" width="290" height="260" />
  < region id="text_region" left="5" top="270" width="290" height="25" background-color="white"/>
  < /layout>
  < /head>
  < body>
  < par>
  < vedio src="/blog_article/test.rm" region="vedio_region" />
  < text src="/blog_article/test.txt" region="text_region"/>
  < /par>
  < /body>
  < /smil>
  说明:
  a、< region id="vedio_region" left="5" top="5" width="290" height="260" />定义多媒体片断显示窗口,它的id是vedio_region,这个id是必须要的(在SMIL中,有的id号是可以省略的,但是我们建议大家都写上,这样很容易把整个SMIL文件的脉络弄清楚)!离顶端和左段各有5个像素点的距离(注意:这里的坐标是相对基本显示窗口而言!)。窗口宽为290个像素点;高为260个像素点。下面的显示窗口的定义和这个是一样的。
  b、< vedio src="/blog_article/test.rm" region="vedio_region" />声明了多媒体片断test.rm在vedio_region这个区域播放;< text src="/blog_article/test.txt" region="text_region"/>声明了文本文件test.txt在vedio_region这个区域显示。
  该例子布局效果如下图:
  上面我们对多媒体片断显示窗口的采用的是绝对定义的方法。多媒体片断显示窗口也可以用相对定义的方法来定义。例如:
  <region id="vedio_region" top="10%" left="10%" width="80%" height="80%"/>
  上面的比例是相对基本显示窗口而言的。这样的定义方法更为直观。
  (3) fit属性
  在实际制作演示的时候,我们碰到了这样的问题:我们定义的显示窗口的大小和我们的多媒体片断的尺寸大小不一致,或大了或小了。相信大家也会碰到这样的问题。解决的办法有:
  a、 修改窗口的大小(但是,很多时候我们没有办法修改。因为,如果修改的话,那么会影响其他窗口的显示。相应的其它窗口也得修改。实际情况是:我们很多的不同尺寸的多媒体片断都可能在同一个窗口中显示!)。
  b、 使用恰当的多媒体片断和窗口的匹配方式。
  看小面这段代码:
  程序代码
  < region id="vedio_region" width="80%" height="80%" fit="meet"/>
  它的意思就是窗口vedio_region以meet方式显示多媒体片断。
  fit属性的属性值有hidden、meet、fill、scroll和slice四个。其中hidden是默认的属性值。
  Hidden表示保持多媒体片断的尺寸不变,从窗口的左上角开始显示。如果多媒体片断尺寸比窗口的尺寸小,那么空白的地方将用背景色填充。如果多媒体片断尺寸比窗口的尺寸大,那么多媒体片断超出窗口部分被裁去,不被显示。个人不喜欢这样的方式。
  meet表示在保持多媒体片断宽/高比例不变的情况下,对多媒体片断的尺寸进行缩放。从左上角开始显示,缩放到高度和宽度中的一个尺寸等于窗口的相应的尺寸,而另外的一个小于窗口的相应的尺寸。空白处用背景色填充。我喜欢这个!
  fill表示缩放多媒体片断使得其大小正好和窗口的大小一致。如果多媒体片断的宽/高比例和窗口的宽/高比例不等,那么多媒体片断就会变形,非常难看。强烈建议不要采用这种方式!
  scroll表示对多媒体片断的尺寸不做什么修改,它以正常的尺寸大小显示。但是,如果多媒体片断的尺寸超出了窗口的尺寸,那么将会相应出现水平或者垂直滚动条。该种发式适合于长时间的多媒体片断的显示。如果多媒体片断的显示时间很短,建议不要使用!
  slice表示在保持多媒体片断宽/高比例不变的情况下,对多媒体片断的尺寸进行缩放。从左上角开始显示,缩放到高度和宽度中的一个尺寸等于窗口的相应的尺寸,而另外的一个大于窗口的相应的尺寸。超出的不分被裁去而不显示。
  各个匹配的效果请参见下图(省去scroll效果)
  (4)z-index属性
  先试运行下面的源程序:
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="300" height="300" />
  < region id="vedio1_region" width="300" height="300" />
  < region id="vedio2_region" left="270" top="270" width="30" height="30" />
  < /layout>
  < /head>
  < body>
  < par>
  < vedio src="/blog_article/testone.rm" region="vedio1_region"/>
  < vedio src="/blog_article/testtwo.rm" region="vedio2_region" />
  < /par>
  < /body>
  < /smil>
  我想大家已经看出来了:我们这里想做的就是那种电视的画中画效果。但是在实际显示的时候,我们的小画面有时候被大画面所覆盖。我的苦心也白费了。z-index属性这个时候是我们的救星。
  修改< region id="vedio1_region" width="300" height="300" />
  < region id="vedio2_region" left="270" top="270" width="30" height="30" />
  成:< region id="vedio1_region" width="300" height="300" z-index="0"/>
  < region id="vedio2_region" left="270" top="270" width="30" height="30" z-index="1" />
  在看看效果,行了吗?J
  z-index属性规定相互重叠的窗口的显示次序。数字大那么显示就在上面。这个很容易理解,我们就不说太多。但是以下几点要注意:
  a、root层窗口总是在最后一层,并且不用z-index属性。
  b、z-index属性值可以是负数。当然它就的排在0以后。
  c、 没有重叠的窗口可以使用同一z-index属性值。
  4、 链接制作
  传统的流媒体的最大的一个弊端是没有交互性(Interaction)。现在如日中天的flash本质上就是一种可交互性的流!由此可见可交互性的流的市场潜力。而SMIL是解决大部分流媒体交互性的最好的工具!这部分要求大家必须掌握,如果没有的话,那么我们学习SMIL就失去了意义。因为这里是SMIL的主要特色(与其他的视频编辑软件相比较),就好像指针是C语言的特色一样。
  (1)< a>< /a>标记
  运行下面这个程序:
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="300" height="300"/>
  < region id="videoregion" top="0" left="0" width="300" height="300"/>
  < layout>
  < /head>
  < body>
  < a href="/blog_article/1.rm">
  < video src="/blog_article/videotest.rm" region="videoregion"/>
  < /a>
  < /body>
  < /smil>
  正常情况下,我们看到播放器播放videotest.rm,如果我们把鼠标放到正在播放的videotest.rm上面,鼠标将有指针形状变为小手形状。单击鼠标左键,播放器播放将停止播放videotest.rm而播放1.rm这个文件。这里我们就成功的创建了一个很简单的链接。属性就是用于链接标记,href表示的是所要链接的文件。这种方法非常简单,我们就不做过多的介绍。
  如果我们要创建更加复杂的链接,我们就要用到下面的这个属性。
  (2)< anchor>属性
  将上例中的< body>< /body>换成下面这段代码,看看效果是不是有区别?
  程序代码
  < body>
  < video src="/blog_article/videotest.rm" region="videoregion">
  < anchor href="/blog_article/1.rm"/>
  < /video>
  < /body>
  我们看到的效果是完全一样的!那么<anchor>属性不就多余了吗? 那是不会的!JJ请看:
  a、 分时断链接
  考虑这样一个问题:我们要在0~10秒链到一个文件,10~20秒链到另一个文件,该怎么办?看我们的:
  程序代码
  < body>
  < video src="/blog_article/1.avi" region="videoregion">
  < anchor href="/blog_article/1.jpg" begin="0s" end="10s" >
  < anchor href="/blog_article/videotest.rm" begin="10s" end="20s" />
  < /video>
  大家将看到的效果:播放器播放1.avi,在0~10秒链到1.jpg,在10~20秒链到videotest.rm。警告:dur、clip-begin和clip-end这里不支持!
  B、链接部分SMIL
  我们的链接可以链接的文件很多,几乎所用的多媒体片断都可以。*.smil和*.html也可以。但是,下面我们要讨论的是如何链接部分SMIL。请看例子。
  第一个SMIL文件,取名test11.smil
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="400" height="300"/>
  < region id="videoregion" top="0" left="0" width="400" height="300" fit="meet"/>
  < /layout>
  < /head>
  < body>
  < video src="/blog_article/1.avi" region="videoregion">
  < anchor href="/blog_article/test11app.smil"/>
  < /video>
  < /body>
  < /smil>
  第一个SMIL文件,取名test11app.smil
  程序代码
  < smil>
  < head>
  < layout>
  < root-layout width="400" height="300"/>
  < region id="videoregion" top="0" left="0" width="400" height="300" fit="meet"/>
  < /layout>
  < /head>
  < body>
  < video id="testlink" src="/blog_article/1.avi" clip-begin="150" region="videoregion"/>
  < /body>
  < /smil>
  大家一定看出来了!我就是在test11app.smil中为我们要链接的那部分内容设上id,然后在test11.smil中的链接中用“#”来指向该标记id。应用的很多的时候是组内内容。我们把test11app.smil修改为:
  程序代码
  < body>
  < par id="testlink">
  < video src="/blog_article/1.avi" clip-begin="150" region="videoregion"/>
  < /par>
  < /body>
  到这里,链接可以说已经很完美了。但是,如果要锦上添花,那么下面这个属性是必不可少的。
  (3)coords属性
  将上面的<anchor href="/blog_article/1.rm"/>代码修改为:
  < anchor href="/blog_article/1.rm" coords="0, 0,150,300"/>
  或者:
  < anchor href="/blog_article/1.rm" coords="0%, 0%,50%,100%"/>
  运行,看看效果。JJ我们看到左半部分有链接效果,而右半部分却没有!这是我们采用了坐标规定链接区的缘故。coords属性值的第一、二个数分别表示的是链接区的左上角点的水平(left)和垂直(top)坐标;第三、四个数分别表示的是链接区的右下角点的水平(left)和垂直(top)坐标。上面用的是像素点的绝对定义方法,下面用的是比例的相对定义方法。喜欢哪一个就看你的喜好了。
  (5)链接注意
  我们的演示最后基本上都要放到服务器上。因此,文件的位置的规定就非常重要,如果文件位置出错,那么播放器将找不到文件而不能播放。这是我们最不希望看到的!下面我们就来讨论这个问题。
  A、创建基地址
  看下面的代码:
  程序代码
  < head>
  < meta. name="base" content="rtsp://abc.5dmedia.com/"/>
  < /head>
  上面就是在< head>< /head>中用附加信息的方式规定了整个smil文件的基地址为rtsp://abc.5dmedia.com/。规定了基地址以后,我们在用该地址下的文件的时候,就只需要给出路径就可以了。例如:
  程序代码
  < body>
  < video src="/blog_article/video/first.rm"/>
  < video src="/blog_article/video /second.rm"/>
  < audio src="rtsp:// abc.mysite.com:554/audio/test.mp3"/>
  < img src="/blog_article/http/%20www_5dmedia_com/image/welcome.jpg"/>
  < /body>
  这个例子中的前面的两个文件用的是基地址服务器上的文件,所以,可以之写出相对地址。但是,后面的两个文件用的是其他服务器上的文件,我们必须给出绝对地址。其中rtsp是实时流传输协议,它保证SMIL播放器正确地从流服务器abc.mysite.com上的audio文件夹下获得我的所要的文件test.mp3。554为流服务器的端口。http是超文本传输协议。它保证SMIL播放器正确地从web服务器www.5dmedia.com上的image文件夹下获得我的所要的文件welcome.jpg。< audio src="rtsp:// abc.mysite.com:554/audio/test.mp3"/>说明的是该文件不在上面的基地址下,而在rtsp:// abc.mysite.com:554/audio/这个地方法,所我们必须修改地址。
  如果我们用的是本地机器硬盘上的文件就可以用src="file:/c:\audio\first.rm"进行读取该文件。
  大家在调用文件之前,一定要弄清楚文件的位置!
  5、语言选择和智能流
  (1)语言选择
  如果,我们想要扩大我们演示的收看人群,那么我们的听众就会有中国人、美国人、法国人、俄罗斯等等。那么怎样才能提供这种多国语言的支持呢?
  Switch属性是该问题的“杀手”!
  请看例子:
  程序代码
  < smil>
  < body>
  < switch>
  < video src="/blog_article/English.rm" system-language="en-us"/>
  < video src="/blog_article/Chinese.rm" system-language="zh-cn"/>
  < /switch>
  < /body>
  < /smil>
  在SMIL播放器播放该SMIL文件时,检测你的播放器设置的是什么语言,如果是美国英语(en-us),那么就从服务器下载English.rm播放;如果是简体中文(zh-cn),那么就从服务器下载Chinese.rm文件播放。你可以设置很多的国家的选项。当然你的语言的版本也就很多了。J下面我们给出经常使用的一些语言的代码。
  代码 语言
  zh-cn 中文 (中华人民共和国)
  en-us 英语 (美国)
  fr 法语 (标准法语)
  de 德育(标准德语)
  it 意大利语(标准意大利语)
  ja 日语
  es 西班牙语(西班牙)
  2)智能流(surestream)
  用户的联网速度是不尽相同的。有的可能只有50K左右,有的可能有几百K。如果我们满足了高速用户的要求,那么低速用户可能由于速度太慢而不能收看。如果我们满足了低速用户的要求,那么高速用户看到的效果就打了不少的折扣,浪费了高速的带宽。怎么办?
  程序代码
  < smil>
  < body>
  < switch>
  < vedio src="/blog_article/highspeed.rm" system-bitrate="250000"/>
  < vedio src="/blog_article/midspeed.rm" system-bitrate="80000"/>
  < vedio src="/blog_article/lowspeed.rm" system-bitrate="20000"/>
  < /switch>
  < /body>
  < /smil>
  当用户的联网速度大于250kbps时,播放器就从服务器下载highspeed.rm播放;如果用户的联网速度大于80kbps小于250kbps时,播放器就从服务器下载midspeed.rm播放;如果用户的联网速度大于20kbps小于80kbps时,播放器就从服务器下载lowspeed.rm播放。所谓的“众口难调”在各位的手里就变得如此简单!J
  上面讲的就是智能流(surestream)的本质实现方法!我们下面看一个复杂的一点的例子。
  程序代码
  < body>
  < switch>
  < par system-bitrate="225000">
  < !--联网速度大于250kbps时,播放该组-->
  < audio src="/blog_article/audio/music1.rm"/>
  < video src="/blog_article/video/video1.rm" region="videoregion"/>
  < text src="/blog_article/words/narration.txt" region="textregion"/>
  < /par>
  < par system-bitrate="80000">
  < !--联网速度大于80000bps而小于250000bps时,播放该组-->
  < audio src="/blog_article/audio/music2.rm"/>
  < video src="/blog_article/video/video2.rm" region="videoregion"/>
  < textstream src="/blog_article/words/narration.rt" region="textregion"/>
  < /par>
  < par system-bitrate="20000">
  < !--联网速度大于20kbps而小于80kbps时,播放该组-->
  < audio src="/blog_article/audio/music3.rm"/>
  < video src="/blog_article/video/video3.rm" region="videoregion"/>
  < text src="/blog_article/words/narration.txt" region="textregion"/>
  < /par>
  < /switch>
  < /body>
  (3)语言与速度的同时检测
  程序代码
  < body>
  < switch> < !—简体中文并且速度大于28kbps -->
  < text src="/blog_article/Chinese_14000.txt" system-language="zh-cn" system-bitrate="28000" /> < !--简体中文并且速度大于14kbps -->
  < text src="/blog_article/Chinese_28000.txt" system-language="zh-cn" system-bitrate="14000" /> < !—美国英文并且速度大于28kbps -->
  < text src="/blog_article/english_14000.txt" system-language="en-us" system-bitrate="28000" /> < !--美国英文并且速度大于14kbps -->
  < text src="/blog_article/english_28000.txt" system-language="en-us" system-bitrate="14000" />
  < /switch>
  < /body>
  (4)演示速度的控制上面我们讲的是在演示文件已经创建好的条件下进行的。那么,我们怎样制作好多媒体片断。下面是我们的建议:a、 用Realproducer或者其他的压缩工具制作流文件时,选择正确的压缩比例。为高速用户准备的文件的压缩比可以小一些,对于低速用户准备的文件的压缩比要大一点。b、 在网络传输过程中,视频占用的带宽是最多的,音频次之,接下来是动画、图片,文字是最少的。所以,我们充分考虑我们的演示的结构。例如:如果并行播放多个视频,这显然是不合适的。我们可以用图片来替代一部分视频效果。
  c、 我们在传输中不能全部占用用户的带宽,必须留出一部分给用户浏览网页或者是干其它用途的。JJJ我们很多的年轻人当然是用于QQ 聊天!下表列出了我们的建议。
  用户速度 建议最大流占用带宽
  14.4 Kbps modem 10 Kbps
  28.8 Kbps modem 20 Kbps
  56 Kbps modem 34 Kbps
  64 Kbps ISDN 45 Kbps
  112 Kbps dual ISDN 80 Kbps
  Corporate LAN 150 Kbps
  256 Kbps DSL/cable modem 225 Kbps
  384 Kbps DSL/cable modem 350 Kbps
  512 Kbps DSL/cable modem 450 Kbps
  在我们以后的制作中。上面的这些知识是非常实用的。大家一定要努力掌握!
  6、 动画效果
  我们前面学习的内容是SMIL1.0规定的。在SMIL2.0中添加了不少的内容,其中动画就是其中一个。很多的国外的教程上把flash文件*.swf归为这一类。我们不能同意这样的分类方法。我们认为把这样已经做好的动画该归为视频一类。真正的动画(从SMIL2.0规范中可以看出来)是有SMIL规定的并有SMIL播放器解释产生的动画。
  从实际情况来看,动画效果主要是针对图片产生的。所以,我们在这里用图片来做例子。其他的多媒体的制作方法是类似的。有兴趣的GG、JJ、DD和MM可以自己做做。
  (1) 运动动画
  为先睹为快,请在Realone player中运行下面的程序:
  程序代码
  < smil xmlns="http://www.w3.org/2000/SMIL20/CR/Language">
  < head>
  < layout>
  < root-layout width="800" height="600"/>
  < region id="Images" left="0" width="800" height="600"/>
  < /layout>
  < /head>
  < body>
  < img region="Images" src="/blog_article/g03.jpg" dur="6s">
  < animateMotion from="0 0" to="600 400" dur="4s"/>
  < /img>
  < /body>
  < /smil>
  解释:a、我们这里用到的是SMIL2.0规范中的规定的内容的。所以,在第一行里(xmlns="http://www.w3.org/2000/SMIL20/CR/Language")我们必须声明我们所用的规范。不然的话,播放器可能不能正确解码、播放。
  b、 animateMotion标记声明的是我们所要的动画类型。注意:这里就是我们所说的骆驼写法,还记得吧!JJ
  c、 from="0 0" to="600 400"属性及其属性值声明的是动画从坐标点(0,0)运动到坐标点(600,400)。这里我们也可以写成:< animateMotion from="0,0" to="600,400" dur="4s"/>
  d、 dur="4s"属性及其属性值声明的是动画在4秒内完成。在我们这个例子中,图片的存在时间是6秒,那么动画完成后,将有2秒钟的时间静止不动。如果图片的存在时间小于动画存在时间,那么动画运动到半路上就的停止,这样的情况是该避免的。
  (2) 缩放动画
  下面我们看看另外的一种动画形式:缩放动画。先看效果!J
  程序代码
  < smil xmlns="http://www.w3.org/2000/SMIL20/CR/Language">
  < head>
  < layout>
  < root-layout width="800" height="600"/>
  < region id="Images" left="0" width="800" height="600" fit="meet"/>
  < /layout>
  < /head>
  < body>
  < img region="Images" dur="10s" src="/blog_article/g03.jpg" width="400" height="320">
  < animate attributeName="height" from="320" to="160" fill="freeze" dur="10s"/>
  < /img>
  < /body>
  < /smil>
  解释:animate attributeName="height" from="320" to="160"声明了动画的类型和参数。大家看了效果以后,在结合上面的参数的意义,各参数是什么意思我们也就不用多讲了。J
  7、 转场效果 首先解释一下什么是转场效果。我们的演示中多媒体片断是很多的,不可避免的会有两个片断之间的切换。例如:一个图片演示完了,该接着演示下一个图片,两图片中间是有一个过渡的。这个过渡我们就称谓转场效果。如果我们不设置转场效果,那么,过渡的效果肯定不好。LSMIL中的转场效果大致分为wipe和fade两类。(1) fade类型从名字就可以看出,这个是淡入淡出的效果。先睹为快!J 请看例子!
  程序代码
  < smil xmlns="http://www.w3.org/2001/SMIL20/Language">
  < head>
  < transition id="fade1" type="fade" subtype="fadeToColor" dur="4s" />
  < transition id="fade2" type="fade" subtype="fadeFromColor" dur="4s" />
  < /head>
  < body>
  < img src="/blog_article/g04.jpg" dur="10s" transIn="fade2" transOut="fade1"/>
  < /body>
  </smil>
  解释:a、transition声明我们要设置转场效果。id="fade1"设置了该转场效果的id号。id号必须设置。type="fade"设置了转场效果的基本类型为fade。 subtype="fadeToColor"设置了转场效果的具体类型(子类型)为fadeToColor(注意这里又是我们提到的骆驼写法!)。dur="4s"设置了该场效果完成的时间。b、transIn="fade2"设置了图片g04.jpg显示时采用转场效果fade2; transOut="fade1"规定图片g04.jpg完成显示时采用转场效果fade1。c、fade只有三个子类型。上面我们用了2个。还有一个是crossfade,这个也是缺省设置。
  (2) wipe类型
  wipe为擦去类型。该类型的效果很多很多。我们这里所说的wipe只是他们的总称(注意wipe不能作为type的属性值,而是它的子类作为type的属性值,子类的子类作为subtype的属性值!J谁让它的属性值这么多!!!)。具体的有barWipe、boxWipe、fourBoxWipe等36大类!!!不管它有多少类,先看看怎么弄。请看例子:
  程序代码
  < smil xmlns="http://www.w3.org/2001/SMIL20/Language">
  < head>
  < transition id="wipe1" type="slideWipe" subtype="fromTop"/>
  < transition id="wipe2" type="waterfallWipe"/>
  < /head>
  < body>
  < img src="/blog_article/g03.jpg" transIn="wipe1" transOut="wipe2" dur="5s"/>
  < /body>
  < /smil>
  解释:a、JJJ和上面的写法基本上是一致的!
  b、type="waterfallWipe"后面没有子类型表示使用的是waterfallWipe类型的默认子类型。
  (3) 综合应用
  我们上面都只是用在单个多媒体片断上的转场效果。下面看看在多个多媒体片断上怎样设置转场效果。还得看例子:J
  程序代码
  < smil xmlns="http://www.w3.org/2001/SMIL20/Language">
  < head>
  < layout>
  < root-layout width="400" height="300"/>
  < /layout>
  < transition id="fade" type="fade" subtype="fadeToColor" fadeColor="green" dur="4s"/>
  < transition id="fade1" type="fade" subtype="fadeFromColor" fadeColor="red" dur="4s"/>
  < transition id="fade2" type="fade" subtype="crossfade" dur="2s"/>
  < transition id="push" type="snakeWipe" dur="4" />
  < /head>
  < body>
  < seq>
  < img dur="5s" src="/blog_article/g06.jpg" transIn="fade1" fill="transition"/>
  < img dur="4s" src="/blog_article/g05.jpg" transIn="fade2" fill="transition"/>
  < img dur="4s" src="/blog_article/g06.jpg" transIn="fade2" fill="transition"/>
  < img dur="4s" src="/blog_article/g05.jpg" transIn="push" transOut="fade"/>
  < /seq>
  < /body>
  < /smil>
SMIL的优点
  SMIL语言是一套已经规定好的而且非常简单的标记。它用来规定多媒体片断(这里多媒体的包括的范围有:声音文件、视频文件、动画、图片、文字等)在什么时候、在什么地方、以什么样的方式播放。糊涂了吗?J 我们下面一起来看看SMIL的优点(与众不同的地方!):
  为了方便起见,我们把我们想要完成的作品称之为演示(presentation)。
  (1) 避免使用统一的包容文件格式
  因为我们的多媒体文件的格式的时非常多的,例如:像声音就有*.mp3、*.wav、*.ra等等;视频的格式更是多的出奇:*.mpg、*.avi、*.mov、*.rm等等;图片的格式就更加不用说了。J 如果我们想在本地机器上直接播放或者在网络上用流式播放的方式来播放若干个文件。当然我们希望的是不要总让我们自己打开文件。而是,在上一个文件播放完成以后,就播放下一个。播放列表是个办法。但是,如果格式不一样,并且要求多个片断同时播放(例如:显示图片的同时,有解说的声音。图片和声音是两个文件),那么以前唯一可行的办法就是用对媒体的编辑软件把这些多媒体文件整合成一个文件。这就必须统一使用某种文件格式。如果你的源文件(多个多媒体片断)没有保存副本的话,在你下次要用其中的某个源文件的时候,J 你就后悔去吧!如果我们用SMIL来组织这些多媒体文件,那么可以在不对源文件进行任何修改的情形下,获得我们想要的效果(从这里来看,SMIL好像是穿珍珠项链用的金丝线,只是把它们穿起来组成一个整体,而不会破坏它们。)。当然SMIL的功能决非就这么点。接下来就是:
  (2)同时播放在不同地方(服务器上)的多媒体片断
  如果上面第一点你还可以用其他的办法做到,那么这一条恐怕你就没辙了?font face="Wingdings">J 考虑这样一个实际问题:假如我们现在想把一段电视采访的实况(视频文件)加上解说(包括声音解说(音频文件)和文字解说)。姑且假定例子中的视频文件是甲服务器上的A文件,音频文件是乙服务器上的B文件,而解说文字却是丙服务器上的C文件。传统的方法在这里就束手无策了(穷途末路了J),而SMIL可以非常轻松的做到这一点。
  (3)时间控制
  如果我们不想用整个视频文件,而只想用其中的某一部分。传统的方法中唯一可行的就是用剪辑软件来剪辑。费时费力不说,弄不好就弄巧成拙,把想要的给剪掉了!而SMIL完成这件事真的是易如反掌!看这样一个例子:设视频文件A的时间长度是10秒,我们要用的是2~5秒,其他部分我们不想要,只要用SMIL规定:在该视频文件A的第二秒开始播放,播放到第五秒结束就可以了。
  时间控制的另外的部分是动画和转场效果。如果上面的时间控制是丝绸,那么这个就是在它上面的双面刺绣!后面我们将要详细讨论这个问题。J
  (4)对整个演示进行布局
  我们把上面提到的那个例子拿来说明这个问题:由于我们有视频、有文字我们希望什么样的布局呢?一般的情形下在一个区域(屏幕的上部)播放视频,在另一个区域显示文字(屏幕的底部)。当然,如果你认为在视频上面显示文字效果更好的话,那也是可以的。用SMIL实现这样的效果异常容易!
  (5)多语言选择支持
  分析这样一个实际例子:我们要为某种产品作宣传,其宣传对象是多个国家的人,有英语国家的、有法语国家的、有德语国家的等等。当然最主要是讲中文的国家的人(我是中国人!)。如果我们想要所有的人都可以听懂、看懂我们的介绍,那么我们就的准备不同语言版本的媒体文件。传统的方法是让用户来选择,然后从服务器上下载相应的版本。麻烦就不用讲了。万一我们的选择老外都看不懂(有时候,我到德文、日文、朝鲜文的站点上,就不知道他们讲些什么东西L),这怎么办?如果把他们用SMIL来组织起来、规定好,那么SMIL语言将根据具体的语言设置来播放相应版本的演示。就是方便!J
  (6)多带宽选择支持
  由于各个用户连接到Internet的方式不尽相同,所以其连接的速度差别也较大。为了让他们都能够看到我们的演示,我们可以制作适应不同传输速度的演示。在传统的方法中,往往要用户自己选择他的机器连接所对应的传输速度,然后播放相应得演示文件。这确实解决了一些问题。实际上,并不是所有的用户都知道自己的连接速度,就是知道了,还得选择不也是非常麻烦吗?L SMIL解决这个问题如同吹灰!播放器检测出用户的连接速度后,就同服务器“协商”,要求传输并播放相应的演示文件。

    
[2] 翻页成效
    来源: 互联网  发布时间: 2014-02-18
翻页效果
显示sd卡中txt文件。

    
[3] 应用程序签字
    来源: 互联网  发布时间: 2014-02-18
应用程序签名

这篇文章将阐述在应用程序发布前有关应用程序签名的内容。

概述

Android系统要求,所有的程序经过数字签名后才能安装。Android系统使用这个证书来识别应用程序的作者,并且建立程序间的信任关系。证书不是用于用户控制哪些程序可以安装。证书不需要授权中心来签名:Android应用程序上使用自己签名的证书是完全允许且普遍的。

理解Android应用程序签名有以下几个重要点:

·           所有的应用程序都必须签名。系统不会安装任何一个不签名的程序。

·           你可以使用自己的证书来签名。不需要任何授权中心。

·           当你要为最终用户发布你的应用程序的时候,你必须签入一个合适的密钥。你不可以发布程序的时候还使用SDK工具签入的Debug Key。

·           系统只在安装应用程序的时候检测证书的有效期。如果应用程序在安装之后证书失效了,那么,应用程序还是可以正常工作。

·           你可以使用标准工具——Keytool和Jarsigner——生成Key并签名apk文件。

·           一旦你为应用程序签名了,一定要使用zipalign工具来优化最终的APK包。

Android系统不会安装和运行没有正确签名的应用程序。这条规则适用于任何运行Android系统的地方,不管是真机还是模拟器。正是由于这个原因,你必须在模拟器或真机上运行/调试程序之前对程序进行签名。

当你调试应用程序时,Android SDK工具替你对应用程序进行了签名。Eclipse的ADT插件和Ant编译工具都提供了两种签名模式——Debug模式和Release模式。

·           当开发和测试时,你可以使用Debug模式。在Debug模式下,编译工具使用内嵌在JDK中的Keytool工具来创建一个keystore和一个key(包含公认的名字和密码)。在每次编译的时候,使用这个Debug Key来为apk文件签名。由于密码是公认的,在每次编译的时候,也不需要提示你输入keystore和key密码。

·           当你的程序准备发布时,你必须在Release模式下,使用密钥来为apk文件签名。有以下两种方式可以做到:

o    命令行中使用Keytool和Jarsigner。在这个方法中,首先需要编译出一个未签名的apk。然后使用Jarsigner(或相似的工具),用你的密钥为apk手动签名。如果你没有合适的密钥,你可以运行Keytool来手动生成自己的keystore/key。

o    使用ADT导出向导。如果你使用Eclipse/ADT插件进行开发,你可以使用导出向导来编译程序,生成密钥(如果需要),并为apk签名,所有这些操作都在导出向导中。一旦你的程序签名了,别忘了运行zipalign来为apk进行额外的优化。

签名策略

应用程序签名的某些方面可能会影响应用程序的开发,特别是你打算一起发布多个应用程序的时候。

一般来说,推荐的策略是在整个应用程序寿命内,所有的程序签上相同的证书。以下有几个应该这么做的原因:

·         应用程序升级——当你对应用程序进行升级时,如果你想用户平稳的升级,那么,你就需要签上相同的证书。当系统安装一个升级应用程序时,如果新版本的证书与老版本的证书有匹配的话,那么,系统才会允许进行升级。如果你没有为版本签上合适的证书,当你安装时,你需要给应用程序指定一个新的包名——在这种情况下,用户安装的新版本,被当作是一个全新的应用程序。

·         应用程序模块化——如果应用程序请求的话,Android系统允许签有相同证书的应用程序运行在相同的进程里,这样,系统就会把它们看作是一个单一的应用程序。用这种方法配置应用程序,用户可以选择更新每个独立的模块。

·         代码/数据权限共享——Android系统提供了基于签名的权限检查,因此,如果应用程序间签有特定的证书,那么,它们之间可以共享功能。通过多个程序签有相同的证书并且使用基于签名的权限检查,你的程序可以以一种安全的方式共享代码和数据。

还有一个决定签名策略的重要因素是:如何设定key的有效期。

·         如果你计划支持单个应用程序的升级,你需要确保你的key拥有一个超过期望的应用程序生命周期的有效期。推荐使用25年或更多的有效期。当你的key过期了,用户也就不能平稳的更新到新版本了。

·         如果你想给多个无关的应用程序签上相同的key,那么,你必须确保key的有效期超过所有应用程序所有版本的生命周期,包括将来有可能添加到这一阵营的程序。

·         如果你想在Android Market上发布你的程序,key的有效期必须在2033.10.22以后。Market服务器强制这一要求,目前是保证用户可以平稳的更新他们的程序。

当你设计应用程序时,一定要把这些点记在脑子里,并且使用一个合适的证书来为应用程序签名。

签名的基本设定

在你开始之前,你必须保证Keytool对SDK编译工具来说是可利用的。多数情况下,你可以通过设置JAVA_HOME环境变量来告诉SDK编译工具如何找到Keytool。另外,你还可以添加JDK中Keytool的路径到PATH的变量里。

如果你在Linux上开发,并且使用GNU编译器来编译Java,那么,请确保系统是使用JDK中的Keytool,而不是gcj。如果Keytool已经在你的PATH中,它有可能是对/usr/bin/keytool的符号链接。在这种情况下,检查符号链接的目标,确保它是指向JDK中的Keytool。

如果你打算对公众释放你的应用程序,你还需要Jarsigner工具。Jarsigner和Keytool都包含在JDK中。

Debug模式下签名

Android编译工具提供了Debug签名模式,使得开发和调试应用程序更加容易,而且还满足Android系统的签名要求。当使用Debug模式编译你的app时,SDK工具会调用Keytool工具自动创建一个Debug的keystore和key。然后,这个Debug key会自动用于apk的签名,这样,你不需要使用你自己的key来为应用程序包签名。

SDK工具使用预先定义好的名字/密码来创建Debug keystore/key:

·         Keystore名字:“debug.keysotre”

·         Keystore密码:“android”

·         Key别名:“androiddebugkey”

·         Key密码:“android”

·         CN:“CN=Android Debug,O=Android,C=US”

如果需要的话,你可以改变Debug keystore/key的位置和名字,或者提供一个自定义的Debug keysotre/key。然而,任何自定义的Debug keystore/key必须使用和默认Debug key(上面描述的)相同的名字和密码。(在Eclipse/ADT中,操作Windows>Preferences>Android>Build实现。)

注意: 你不能将签有Debug证书的应用程序发布给公众。

 

Eclipse 用户

如果你在Eclipse/ADT下开发(并且已经按照上面描述的“签名的基本设定”配置了Keytool),Debug模式下签名默认是开启的。当你运行或是调试应用程序时,ADT会使用Debug证书进行签名,并运行zipalign,然后安装到选择的模拟器或是连接上的设备。整个过程不需要你参与,前提是ADT能访问Keytool。

Ant 用户

如果你使用Ant来编译你的apk文件,需要在ant命令中添加debug选项来开启Debug签名模式(假设你正在使用由android工具生成build.xml文件)。当你运行ant debug来编译你的程序时,编译脚本会生成一个keystore/key,并为apk进行签名。然后脚本会使用zipalign工具对apk进行对齐处理。整个过程不需要你参与。阅读“其它IDE下开发:Debug模式编译”来了解更多的信息。

Debug证书过期

Debug模式下签名用的证书(默认是Eclipse/ADT和Ant编译)自从它创建之日起,1年后就会失效。

当证书失效时,你会得到一个编译错误,在Ant编译上,错误如下:

debug:
[echo] Packaging bin/samples-debug.apk, and signing it with a debug key...
[exec] Debug Certificate expired on 8/4/08 3:43 PM

在Eclipse/ADT中,Android控制台上你将会看到一个相似的错误。

为了解决这个问题,只需要删掉debug.keystore文件即可。AVD默认存储的位置在:~/.android/avd(OS X和Linux),C:\Documents and Settings\\.android\(Windows XP),C:\Users\\.android\(Windows Vista)。

当下一次编译的时候,编译工具会重新生成一个新的keystore和Debug key。

Release模式下签名

当你的程序准备好释放给其它用户时,你必须:

1.   获取一个合适的密钥

2.      在Release模式下编译程序

3.      使用密钥签名程序

4.      对齐APK包

如果你是使用Eclipse/ADT插件开发,你可以使用导出向导来完成编译、签名和对齐等操作。在整个过程中,导出向导甚至还可以生成一个新的keystore和密钥。因此,如果你使用Eclipse,你可以直接跳到“使用Eclipse ADT编译和签名”。

1. 获取一个合适的密钥

为了进行程序的签名,首先,你必须有一个合适的密钥。密钥指:

·         个人持有。

·         代表个人、公司或组织实体的身份。

·         拥有一个有效期。有效期推荐超过25年。

如果你在Android Market上发布你的程序,需要注意一点的是:程序的有效期需要在2033.10.22之后。你不能上传一个应用程序,而它的key的有效期是在这个日期之前。

·         不是由Android SDK工具生成的Debug key。

如果你没有一个合适的key,你一定要使用Keytool来生成一个。如“基本设定”中描述的,确保Keytool可用。

为了用Keytool生成一个key,使用keytool命令并传入一些可选参数,如下表所示。

警告: 确保密钥的安全。一定要阅读“安全储存你的密钥”中讨论如何确保你的密钥的安全以及这对你和用户为何如此重要。尤其是,当你生成你的密钥时,一定要为keystore和key使用强密码。

 

 

 

 

Keytool选项

描述

-genkey

生成一个键对(公钥和密钥)

-v

日志输出

-keystore <keystore-name>.keystore

命名包含密钥的keystore

-storepass <password>

设定keystore的密码。

基于安全考虑,不要在命令行中包含这一选项,除非你在一个安全的计算机上。如果你不提供,Keytool会提示你输入。这样,你的密码就不会储存在shell记录中了。

-alias <alias_name>

设定key的别名

-keyalg <alg>

指定生成key时使用的加密算法。支持DSA和RSA。

-dname <name>

指定一个描述谁创建key的名字。该值将填入证书发行人的字段。

注意:你不需要在命令行中指明这些选项。如果不提供,Jarsigner会提示你输入每个字段(CN,OU等)。

-validity <valdays>

Key的有效期,天数。

注意:推荐使用10000或更大的数。

-keypass <password>

Key的密码。

基于安全考虑,不要在命令行中包含这一选项,除非你在一个安全的计算机上。如果你不提供,Keytool会提示你输入。这样,你的密码就不会储存在shell记录中了。

下面是使用Keytool命令生成密钥的例子:

$ keytool -genkey -v -keystore my-release-key.keystore 
-alias alias_name -keyalg RSA -validity 10000

运行上面的例子命令,Keytool会提示你输入keystore和key的密码,并且会提示你输入key中其它的字段。然后,它会生成一个叫做my-release-key.keystore的文件。keystore和key受你输入的密码保护。keystore中包含一个key,有效期为10000天。别名将在后面用到,在程序签名时指当前这个keystore。

了解更多关于Keytool的信息,请参考http://java.sun.com/j2se/1.5.0/docs/tooldocs/#security。

2. 在Release模式下编译程序

为了给用户释放程序,你必须在Release模式下编译程序。在Release模式下,编译程序不会进行默认签名,并且你需要使用密钥进行签名。

注意: 你不能释放未签名的程序,或签有Debug key的程序。

使用Eclipse

右击Package Explorer中的工程,选择Android Tools>Export Unsigned Application Package,导出一个未签名的apk。然后指定未签名apk的存储位置。(另外,你也可以在Eclipse中打开AndroidManifest.xml文件,打开Manifest Tab,然后点击Export an unsigned APK)。

注意:你也可以使用导出向导来完成编译和签名步骤,参考“使用Eclipse/ADT编译和签名”。

使用 Ant

如果你正在使用Ant,那么你可以在ant命令中加入release选项来开启Release模式。例如,如果你在包含build.xml文件的文件夹上运行Ant,命令可能看起来是这样:

ant release

一般,编译脚本在编译apk的时候不会进行签名。输出的文件位于工程的bin/文件夹中,名为<your_project_name>-unsigned.apk。由于apk文件还没有签名,所以你必须手动的使用密钥进行签名,然后使用zipalign进行对齐。

然而,Ant编译脚本也可以替你执行签名和对齐操作,前提是你在build.properties文件中提供了keystore的名字和key的别名。如果提供了这些信息,编译脚本在执行ant release命令时会提示你输入keystore和key的密码,对包进行签名并对齐。最后输出的文件位于工程的bin/文件夹中,名为<your_project_name>-release.apk。如果按照上述自动签名和对齐操作执行,那么,你就可以跳过下面的手动步骤(步骤3和4)。了解如何在build.properties文件中指定keystore和alias,请参考“其它IDE下开发:Release模式编译”。

3. 使用密钥签名程序

如果你已经准备好要签名的程序包的话,你可以使用Jarsigner工具进行签名。如“基本设定”中描述的,请确保Jarsigner工具可用。此外,确保包含密钥的keystore可用。

为了签名应用程序,你需要运行Jarsigner,并引用应用程序的apk及包含密钥的keystore。下表列出了你可能使用的选项。

Jarsigner选项

描述

-keystore <keystore-name>.keystore

指定包含密钥的keystore的名字

-verbose

日志输出

-storepass <password>

指定keystore的密码。

基于安全考虑,不要在命令行中包含这一选项,除非你在一个安全的计算机上。如果你不提供,Jarsigner会提示你输入。这样,你的密码就不会储存在shell记录中了

-keypass <password>

指定密钥的密码。

基于安全考虑,不要在命令行中包含这一选项,除非你在一个安全的计算机上。如果你不提供,Jarsigner会提示你输入。这样,你的密码就不会储存在shell记录中了

下面是一个使用Jarsigner对my_application.apk进行签名的例子,使用了上面创建的keystore。

$ jarsigner -verbose -keystore my-release-key.keystore 
my_application.apk alias_name

运行上面的示例命令,Jarsigner会提示你输入keystore和key的密码。然后它会修改apk文件,意味着apk文件现在已经签上名了。注意:你可以使用不同的key对apk多次签名。

检验apk文件是否签名,可以使用下面的命令:

$ jarsigner -verify my_signed.apk

如果apk签名正确,Jarsigner输出“jar verified”。如果你想了解更多的细节,你可以尝试这些命令:

$ jarsigner -verify -verbose my_application.apk

或者

$ jarsigner -verify -verbose -certs my_application.apk

上面的命令,添加-certs选项,将会显示“CN=”行,描述谁创建了密钥。

注意: 如果你看到“CN=Android Debug”,这意味apk文件使用Android SDK生成的Debug key签的名。如果你想发布你的程序,你必须使用自己的密钥替换Debug key进行签名。

了解更多Jarsigner的信息,请参考http://java.sun.com/j2se/1.5.0/docs/tooldocs/#security。

4. 对齐APK包

一旦你对apk文件使用密钥进行签名后,一定要运行zipalign进行对齐。这个工具能做到让那些未压缩的数据以特定的字节对齐。以4字节对齐能优化性能。当对齐后,Android系统能通过mmap()阅读文件,即使它们包含二进制数据,而不是从包中拷贝所有的数据。好处是在运行程序时减少了随机读取内存的消耗。

zipalign由Android SDK提供,包含在tools/文件夹下。想对齐签名后的apk,执行:

zipalign -v 4 your_project_name-unaligned.apk your_project_name.apk

-v标志表示开始日志输出(可选)。4表示对齐的字节(不要使用非4的数字)。第一个文件参数是你的签名后apk(输入),第二个文件参数是目的apk文件(输出)。如果你想覆盖已经存在的apk,添加-f标志。

注意: 在你使用zipalign优化包之前,输入的apk必须是使用密钥签名后的。如果在zipalign操作之后再签名,那么对齐操作就白做了。

了解更多信息,请阅读“zipalign”工具的文档。

使用Eclipse/ADT编译和签名

如果你在使用Eclipse/ADT插件,你可以使用导出向导导出一个签名的apk(甚至可以创建一个新的keystore,如果需要的话)。导出向导替你做了所有与Keytool和Jarsigner交互的工作,并且使用GUI来签名应用程序,替代了上面提到的手动编译、签名和对齐的操作。一旦向导完成了编译和签名,也还会使用zipalign执行包的对齐操作。由于导出向导要使用Keytoo和Jarsigner。你应该确保它们是可用的,如“签名的基本设定”中描述的那样。

安全储存你的密钥

维护密钥的安全是极其重要的。如果你让其他人使用了你的key,或者你把keystore和密码放在一个不安全的地方以至于第三方人员找到并使用了的话,那么,你的授权认证和用户的信任都将受到连累。

如果第三方没有经过你的允许拿走了你的key,那个人就可以签名并发布应用程序,并恶意替换或攻击你的正版程序。这个人还可以签名并发布应用程序,利用你的名义来攻击其它程序或者系统自身,或者破坏、偷取用户数据。

开发者的名声依赖于正确的储存你的密钥,直到它过期。这里有几个安全储存密钥的提示:

·         为key和keystore设置强密码。

·         当你使用Keytool生成密钥的时候,不要再命令行中添加-storepass和-keypass选项。如果你这样做了,在shell记录中就可以获取你的密码。

·         相似的,当使用Jarsigner来签名程序时,也不要在命令行中添加-storepass和-keypass选项。

·         不要把密钥给别人或借给别人,不要让未授权的人知道你的keystore和key的密码。

总而言之,只要你在生成、使用和储存密钥时有安全意识的话,它还是很安全的。 


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android根据电话号码获得联系人头像实例代码 iis7站长之家
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3