keil html转换工具,网页转换工具FCARM和makefsfile的使用简介

网页转换工具FCARM和makefsfile的使用简介

[复制链接]

首先在这里要提一下Keil的网页转换工具FCARM.exe的使用,花费了我好几个小时。TI也有一个类似的程序,是Makefsfile,并且源码公开的。

a26d678767e8b431ecd7a25f1936bdc5.gif

1.gif (31.45 KB, 下载次数: 0)

2010-11-8 16:44 上传

a26d678767e8b431ecd7a25f1936bdc5.gif

2.jpg (50.05 KB, 下载次数: 0)

2010-11-8 16:44 上传

这个FCARM.exe,一直认为只要这个custom arguments里边设置好了FCarm.exe的路径就可以在勾选 include in target build后会自动执行这个程序,转换网页文件,这样岂不是很方便,要不把这些网页文件加到右边干什么(后来明白加到右边只是起到浏览和修改的作用),但实质上,Keil在build之前并不执行程序,而是在translating,这样即使你所有的配置都正确,它并不是在执行程序,只是translating。所以不能勾选include in target build,这样做是不行的。不过也有可能是哪个地方我没设置到,有经验的指点一下啊。

a26d678767e8b431ecd7a25f1936bdc5.gif

3.jpg (18.18 KB, 下载次数: 0)

2010-11-8 16:44 上传

这样做问题并没有解决掉,我们要的是方便地在Keil build的时候同时对网页文件自动地经行转换,而不是每次都进入到DOS里边,当然在命令行下可以毫无疑问的正常运行,但并不方便。

这样就有另外一种解决方法,那就是在build前设置运行user 程序:

a26d678767e8b431ecd7a25f1936bdc5.gif

4.jpg (52.41 KB, 下载次数: 1)

2010-11-8 16:44 上传

这样就把问题解决了。

web.inp是个什么文件呢?有了它结合Keil的run user program很方便,它就是把FCARM.exe 这个程序在命令行中执行的时候,后面的参数就保存在这个文件中,和在FCARM后输入命令没什么区别。注意要使用两个@@,两个@作用相当于命令行中的一个@,但是这里两个不可少,后面的地址给出网页源文件相对于工程的所在目录的地址!

a26d678767e8b431ecd7a25f1936bdc5.gif

5.jpg (39.6 KB, 下载次数: 0)

2010-11-8 16:44 上传

a26d678767e8b431ecd7a25f1936bdc5.gif

6.jpg (45.06 KB, 下载次数: 0)

2010-11-8 16:44 上传

所以最后的网页数据应该是26584+18*8=26728/1024=26.1kb

这是不添加网页文件时的大小:

a26d678767e8b431ecd7a25f1936bdc5.gif

7.jpg (10.4 KB, 下载次数: 1)

2010-11-8 16:44 上传

这是添加网页RS_web.c后的大小:采用了三级优化:

a26d678767e8b431ecd7a25f1936bdc5.gif

8.jpg (13.29 KB, 下载次数: 1)

2010-11-8 16:44 上传

可以看到网页文件的数据被完全编译进了RO-data段:足足多了26316字节约25.7k。

发现经过编译之后的大小要变原来的c格式的数据文件要小一点,小了26728-26316=412个字节。由此可见数据文件似乎并没有足量的全部编译。

我们总共转换了17个文件:

a26d678767e8b431ecd7a25f1936bdc5.gif

9.jpg (15.88 KB, 下载次数: 1)

2010-11-8 16:44 上传

17个文件大约39kb,按压缩率89%计算,最后的大小应该是34kb左右,和上面的26kb还是有一段举例。这个34kb是不准确的,经过准确计算这17个文件的大小实际为29704个字节,合29K左右再按压缩率89%计算,约为26436个字节,合25.8K,和上面已经很小的差距了。

也就是说,把所有网页文件的字节数加起来,乘以压缩率,就基本上是最后写进flash里边的大小了。

注意使用FCARM转换后生成的网页数据,一般是结合Keil的RL这种的TCPnet来使用,和TI的makefsfile工具产生的数据有很大的不同,不能简单的通用。

初步看了看,有以下几点不同:

1.FCARM产生的一个C文件,makefsfile产生的是一个.h的头文件

2.FCARM把所有文件生成的数据都放在了一个数组里边,而makefsfile对每一个文件转换成一个数组。

相比Keil自带的这个转换工具,我觉得makefsfile更好用,更灵活。

比如你开发了好几个网页,在当前工程的文件夹myweb下有index.htm,404.htm,styles.css,page1.htm,page2.htm,..然后这些网页中引用的图片都放在了myweb/images下的这个文件夹,而只需要在命令行下(当然如果你要经常修改网页,你也可以按照上面的方法,把它放到Run user Program before build栏里边,这样每次修改了网页之后,只需要重新编译一下即可。)敲入下面的命令就可以转换了:最好是把makefsfile复制到myweb所在的同一个路径上,都在当前工程下。

makefsfile -i myweb -o webdata.h -h -r

-h:生成的网页数据不包含http头部。

-r:修改网页后重新生成相同文件名的网页数据时不用询问,直接覆盖原来的数据文件。

最后我们只需要把这个头文件include到lmi_fs.c文件中,编译之后也是被放到了RO-data段中。

我自己创建的几个简单的例程,我明天会放到网上,供网友参考。

[本帖最后由 academic 于 2010-11-8 16:44 编辑]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值