掌上帝国's Archiver

小虎大哥 发表于 2009-7-13 13:14

★★★从零开始学定ROM★★★一站式手把手教你定制ROM并成为高手!!!

[size=4][color=red]★★★从零开始★★★==手把手教你定制自已的ROM并成为高手!!![/color][/size]
[size=4][/size]
[size=4][b][color=red]本教程大体分为以下几个部分:
1、ROM基础知识;
2、ROM制作工具介绍;
3、ROM定制;
4、ROM定制FAQ;
5、DIY及OEM包制作;
[/color][color=green](其它正在整理中…………敬请期待)
[/color][/b][/size][size=4][b][color=#0000ff]第一部分:ROM基础知识!
    A。名词解释
     1、ROM,RAM,Flash [font='"微软雅黑]Memory[/font]
[/color][font='"微软雅黑][color=red]ROM(Read Only Memory)的全名为只读记忆体[/color][/font],[color=green]是PPC上的硬盘部分[font='"微软雅黑]用来[/font][/color][/b][/size][size=4][b][font='"微软雅黑][color=green]存储和保存数据。ROM数据不能随意更新,但是在任何时候都可以读取。即使是断电,ROM也能够保留数据。但是资料一但写入后只能用特殊方法或根本无法更改,因此ROM常在嵌入式系统中担任存放作业系统的用途
[/color][/font][font='"微软雅黑][color=red]RAM(Random Access Memory)的全名为随机存储记忆体[/color][/font],[color=green]是PPC上的移动存储部分,用来存储和保存数据的。它在任何时候都可以读写,RAM通常是作为操作系统或其他正在运行程序的临时存储介质(可称作系统内存)[/color]
         
[color=red][font='"微软雅黑]Flash [/font][/color][font='"微软雅黑][color=red]Memory[/color][/font][color=black],[/color][color=green][font='"微软雅黑]由于ROM不易更改的特性让更新资料变得相当麻烦,因此就有了Flash Memory的发展 ,Flash Memory具有ROM不需电力维持资料的好处,又可以在需要的时候任意更改资料,我们常见的FLASH Memory有TF卡([/font][font='"微软雅黑]全名:TransFLash卡[/font][font='"微软雅黑]),SD卡(全名:[/font][font='"微软雅黑]Secure Digital Memory Card[/font][font='"微软雅黑]),CF卡(全名:[/font][font='"微软雅黑]Compact Flash卡[/font][/color][/b][/size][color=black][font='"微软雅黑][size=4][b][color=green])等。[/color]
[/b][/size][/font][/color][size=4][b][font='"微软雅黑][color=navy]     2、 XIP,IPL,SPL,RADIO
[/color][/font][color=darkgreen][font='"微软雅黑]XIP(Execute In Place)中文意:立即执行[/font]。[font='"微软雅黑]XIP所起到的作用是让操作系统内核直接在Flash中运行,不需要拷贝到RAM,即指操作系统或应用程序直接从非易失性存储器中执行,这样减少了内核从闪速存储器拷贝到RAM的时间,其采用的非压缩映像也减少了内核自解压的时间,换句话说,XIP直接决定了PPC系统运行和加载程序的时间,也就是直接决定了PPC系统的运行速度。[/font][/color][/b][/size][color=black]
[/color][color=red][font='"微软雅黑][size=4][b]IPL(全称:InitialProgramLoader)中文意:首次装载系统,[/b][/size][/font][/color][size=4][font='"微软雅黑][b][color=green]其负责主板,电源、硬件初始化程序,并把SPL装入RAM,如果IPL损坏,由于不能加载SPL,所以机器将不能装载任何由SPL完成装载的OS系统。[/color]
[/b][/font][font='"微软雅黑][b][color=red]SPL(全称:SecondProgramLoader)中文意:第二次装系统,[/color][/font][color=green]就是负责装载OS操作系统到RAM中,SPL损坏了我们可以烧录机这样的设备来重新写入,或者还可以通过刷入初始的ROM版本来实现重写SPL,我们俗称“寻找原厂ROM救砖”
RADIO,字面理解:无线电通讯,其负责着PPC作为手机功能的通讯功能方面,包括它的电话和上网功能,事实上,RADIO硬件模块已经在手机出厂时已经内置,我们所刷入的不过是作为软件应用层面的东西,因为软件层面的东西决定了RADIO硬件模块接收和传递信号的频段分配,所以硬件RADIO的称谓已经被弱化,我们把这种RADIO软件层面的东东一律称为RADIO。[/color]
[/size][/b][b][size=4][font='"微软雅黑][color=navy]     3、 刷ROM,刷RADIO,解锁,永久解锁
[/color][color=red]刷ROM[/color][/font][color=red]:[/color][color=green]意指将新的ROM刷入PPC,ROM部分包含:[/color][font='"微软雅黑][color=#008000]IPL、SPL、OS、[/color][/font][color=#008000][font='"微软雅黑]EXTROM、[/font][/color][color=#008000][font='"微软雅黑]RADIO、STORAGE等,目前来说,我们刷入的ROM绝大多数只包含OS部分,OS部分包含两个东东:[/font][/color][/size][/b][color=#008000][font='"微软雅黑][b][size=4]XIP、 IMGFS,而这两个正是影响系统层面的主要因素,鉴于其他部分,因为涉及到核心层面的重新写入,可另行重写,所以我们在此进行了抛弃,为了省事,也降低了一次性刷入的风险。
[color=red]刷RADIO[/color][/size][/font][/color][size=4][color=red]:[/color][color=green]简单的说就是刷入新的RADIO模块的应用软件,不同的地区不同的通讯服务网络,无线通讯基站在接收和发送无线信号上的频段各有不同,那么处于这个地区和这个通讯服务网络之内的RADIO硬件模块,在频段调整上越接近于本地基站,手机的通讯信号就会越好,信号接收和发送就会越完整越快速,信号搜索上也会越稳定,从而使我们的PPC信号强劲又省电,运营商新的RADIO是根据其基站的新的频段来调整的,所以随着时间的推移,当基站有所升级其频段有所调整的时候,新RADIO的刷入就很有必要了。
[/color][color=red]解锁[/color]:[color=green]PPC机器在出厂的时候对机器内部核心的CID地址段进行了上锁,上锁的原理是基于微软对于开放性的WM系统所提供的一种特权保护机制,该机制对应用程序能够访问的系统资源作了限制,而厂家正是利用这一点实现了对系统ROM的锁定,锁定的目的一方面是为了个不同机型间的区别和独立性,更大的原因是保障厂家对WM系统推陈出新上的独立自主权,锁定被集中在机器CID地址段上,不同CID的ROM相互之间不能进行交互性的替换,如果强行刷入CID不同的ROM,将无法通过CID校验,严重的会出现系统无法修复的现象,由此PPC玩机的"江湖大侠"们便做起了文章,衍生出一种通过CID地址段欺骗的手段来对上锁的CID进行XX,XX过的CID刷入后,再刷入其他不同CID的ROM将极大可能地通过校验(但不是100%都可行)从而将新的ROM写入机器.
[/color][color=red]永久解锁[/color]:[color=green]又称[/color][color=red]SuperCID[/color],[color=green]此种新XX的CID和上面的相比具备更大的优势在于新ROM作刷入操作的时候,如若操作失败,原机系统将不会受到较大损伤,就算造成损伤也很容易被修复,所以我们常称此种解锁能使PPC“拥有不坏之身”。[/color]
[/size][/b][size=4][font='"微软雅黑][color=navy][b]     4、重启,硬启,定屏,假死,死机
[/b][/color][/font][font='"微软雅黑][b][color=red]重启[/color][/font][color=red]:[/color][color=green]人人都懂的问题,和PC重启的机制是一样的,ROM中的数据全部保存完好,但是RAM中的数据全部丢失,正因此,通过重启可以解决RAM中运行不正常的现象,比如系统运行中的死机,比如程序模块找不到等问题,大部分的机器都会在一定时间内做重启操作,不是因为断电,而是由于机器运行一段时间之后会有相当一部分的垃圾缓存在RAM中,这是由于我们频繁操作机器造成的,众所周知,RAM剩余得越少,机器运行可用的运行空间就越小,机器的速度也会越慢,耗电量也会增大,那么重启机器在关机的一瞬间RAM里的所有数据全部丢失,包括系统垃圾,在重新开机之后,系统会重新加载应用程序,这时候RAM是一个相对干净的空间。重启的方式大家都知道,连我地球人也知道了,通过电源键,通过系统应用程序,通过桶PP。[/color]
[color=red]硬启[/color][color=red]:[/color][color=green]和重启一样都需要重新启动机器,所不同的是硬启将丢失所有ROM和RAM中的数据,而重启只丢失RAM,硬启后系统会自动还原为初始状态,所有的设定要重新来做,所有的资料要重新拷贝进去,貌似PC上的一键还原机制;硬启的原理是利用机器自身进行了格式化,所不同的是格式化之后机器ROM里的初始数据将被重新调出,这个初值数据一直都存在于ROM之中,你无法删除,纵使你作了替换修改等操作,貌似已经修改了数据,其实不然,只是被系统暂时隐藏了,那么在实行硬启格式化ROM之后,重启机器初始数据会被调处进行加载。硬启操作一般大家不常用,除非系统ROM里出现了无法修复的错误导致机器不能正常运行,那就只能通过硬启来修复系统,硬启的方式地球人都知道,按住挂断和接听两个硬按键桶PP,或者1234清除内存。[/color]
[color=red]定屏[/color][color=red]:[/color][color=green]顾名思义,就是屏幕定住不动不理会你的操作,PPC中的定屏现象主要指的是在开机三屏(或者两屏)上,正常情况下开机之后随着系统的加载,开机屏幕会逐步跳过直到出现调整的界面,但是因为ROM制作中出现错误或者遗漏,导致新ROM刷入之后开机屏幕跳不过去了,无论你等待多长时间,手机屏幕定格在那不动了,无法进入系统,导致刷机失败,之所以解释定屏是因为在后面的解决疑难杂症里会用到这个词。[/color]
[color=red]假死[/color][color=red]:[/color][color=green]又称睡死,非真正的死机现象,假死现象指的是机器表面上运行正常,但是后台的部分应用程序不能被激发,比如在待机模式下电话呼入屏幕无显示无铃声,比如在操作某项程序的时候出现激发暂时性无反应或者反应延时过长。[/color]
[color=red]死机[/color][color=red]:[/color][color=green]人人都知道,这个就不说了。[/color]
[/size][/b][color=navy][b][size=4]    5、 三色屏
[/size][/b][font='"微软雅黑][size=4][b][color=red]三色屏:[/color][color=green]因该模式下屏幕上呈现三种色彩而得名,三色屏模式最直接的作用是用于查看机器IPL值和SPL值,以识别手机是否成功解锁,间接作用是在模式下可以进行刷机操作。所有的刷机操作必定要在三色屏模式下实现,不论你是直刷还是卡刷;手动进入三色屏的方法是按住相机键捅PP重启手机,至于其他关于三色屏的内容留到后面再讲。[/color]
   [/b][/size][/font][/color][b][font='"微软雅黑][size=4][color=navy]B、系统原理[/color][/size][/font][/b]
[b][size=4][color=green]微软的WM系统平台和其PC系统平台有着惊人的相似性,而[font='"微软雅黑]IPL与SPL实质为WM的Bootloader里的两大组成部份,[/font][/color][/b][/size][b][size=4][color=green][font='"微软雅黑]前面说了,IPL[/font][font='"微软雅黑]负责主板,电源、硬件初始化程序、并把SPL装入RAM的,SPL则是负责装载OS操作系统中[/font][font='"微软雅黑]的,所以开机启动顺序是[/font][font='"微软雅黑][/font][font='"微软雅黑]IPL>SPL>OS,SPL还提供[/font][/color][/size][/b][b][size=4][font='"微软雅黑][color=black][color=green]检测手机硬件、寻找系统启动分区、启动操作系统为系统的基本维护提供操作界面以及检测SD卡等,像我们执行刷机操作的时候,也是SPL在发挥作用,比如连接电脑同步,进入三色等。[/color]
[/color][color=blue]在SPL装载OS的时候,前面我们提到[/color][/font][color=#008000][font='"微软雅黑]OS分区又分为XIP、 IMGFS两部分,[/font][/color][color=#008000][font='"微软雅黑]系统启动时SPL加载OS分区的XIP到RAM执行,XIP就是WINCE XIP KERNEL,是CE核心部分,XIP是为eXecute In Place的缩写,在微软的CE定义中,这块区域存放的是以非压缩格式存放,不需加载,由Bootloader直接调用执行。[/font][/color][color=blue]XIP部分大约3MB,包括nk.exe、device.exe等核心程序,就像 PC上的ntoskrnl.exe等。[/color][color=#008000][font='"微软雅黑]IMGFS就像一个压缩的GHOST文件,包括了WM的所有系统文件。CE核心启动后就可以访问IMGFS文件系统上的OS需要的所有文件了,IMGFS是XPR或LZX压缩格式,系统访问上面的文件会自动解压到RAM。[/font][/color][/size][/b][color=#008000][font='"微软雅黑][size=4][b]因为普通PE文件调入RAM执行要进行地址重定位,为了提高效率,IMGFS中的文件可以是重定位好的模块形式,这些程序运行就不用再重定位了,直接调入RAM中保留的PagePool(缓冲池)执行。
[/b][/size][/font][/color][color=#008000][font='"微软雅黑][size=4][b]刷机就是重写OS分区了,用PDOCREAD可以把整个OS分区读成一个NB镜象文件,然后把镜象解开到DUMP文件夹,就是所有ROM的文件了。文件分2种,一种是普通文件,另一种是XIP(ExecInPlace)模块,这是为了加快OS运行设计的,就是这些文件可以不调入RAM而直接在ROM执行,但因为现在都是NAND ROM,所以XIP模块其实还是要调入RAM的PAGEPOOL执行。
但是由于XIP模块有很多地址信息,所以移植OS最难的就是这了。[/b][/size][/font][/color]
[b][size=4][color=#0000ff]第二部分:ROM制作工具介绍!
       A、ROM工具简介
[/color][/size][/b][font='"微软雅黑][size=4][color=black][b][color=green]ROM 文件系统的架构基于WM平台,核心的系统层面的东西实质上我们是编译不了的,ROM制作其实上只是一种组件模块的重新排列组合的过程,先解包,然后添加删除或者替换,再进行打包以及转换,完全是“拿来主义”的做法 ,除了微软能对系统核心层做改变之外,任何第三方目前尚无能力进行实质性的改动,其中包括部分PPC厂商对基于WM系统层面的UI再造。
正因此,ROM制作的难易程度和整体性能90%取决于ROM制作工具,一个好的制作工具不仅事半功倍,还能最大可能减少制作过程产生的错误和麻烦[/color][color=green](熟手建议飘过文字阶段)。[/color]
[/b][/color][/size][/font][font='"微软雅黑][color=navy]
[b][size=4][color=red]PPC在发展,PPC的使用者也在进步,工具越人性化对使用者的操作要求就会越高,反之,工具越傻瓜对操作者的要求也就越低,江湖上于是出现了针对不同机型不同组件以及不同操作步骤的傻瓜式工具,乃至我们经常提到的一键定制模板。在这里,我只想通过定制ROM组件的方式来介绍ROM定制工具,定制包实在太多,不可能去一一举例说明。[/color]
[/size][/b][/color][/font][size=4][font='"微软雅黑][color=navy][b]      B、ROM结构及组件模块[/b][/color][/font]
[/size][font='"微软雅黑][b][size=4][color=black][color=green]上面我们说了定制ROM实质上是对ROM进行解包转换然后对其组件进行添加删除和替换然后再封包转换,那么ROM定制工具包当然就是为了解决这个过程而生了。[/color]
[/color][color=purple]我们首先来看看一个完整的ROM在解包后的几个组成部分:
SPL
IPL
OS[/color][/size][/font][/b][font='"微软雅黑][b][size=4][color=purple]([/color][/size][/font][/b][size=4][color=purple][font='"微软雅黑][b]Operating System [/b][/font][font='"微软雅黑][b])[/font][/color][/size][/b][font='"微软雅黑][b][color=black]
[size=4][color=purple]EXTROM
RADIO
STORAGE

[/color][color=green]上面的列表是对于一个完整ROM来说的,像这样的结构一般源于官方ROM,而实际上我们所需要进行刷新写入的部分只有操作系统OS部分,其他部分已经被隔离开了。
OS组件:
XIP
SYS
OEM软件包
核心组件及驱动
由上可以看出要做出新的OS需要准备XIP,SYS,OEM软件包,核心组件及驱动这几样材料,而这几样材料都可以是现成的,我们所要做的只是想法通过定制工具将他们打包到一起,做ROM其实就这么简单![/color]
[/size][/color][/font][/b][font='"微软雅黑][b][size=4][color=navy]        C、ROM定制工具包的功能
[/color][/size][/font][/b][b][size=4][color=navy][color=green]大部分的ROM采用的是NBH或者NBF文件结构,因为只有这样才能在WM平台之下被识别并刷入,但是我们的操作平台却是PC,这就造成了两个平台之间核心层面的矛盾,ROM定制工具就是解决这种矛盾而生的。
ROM工具包要完成的使命有:
转换文件格式
解包文件为PC环境识别
衔接动态数据库
映射文件地址
嵌入功能模块
封包文件

[/color][color=red]上面的这些我们可以不用去管它到底是怎么意思以及怎么在现实,我们只需要了解下定制工具这个大概的功能就行了。[/color]
               [/color][/size][/b][font='"微软雅黑][b][size=4][color=navy]D、ROM定制包的应用
[/color][color=green]很多机油曾经也看过很多教程,但是在常试定制ROM上依然未取得较大的进展(当然使用傻瓜工具的除外),鉴于这种情况,我们不妨采取化整为零的方式来一步步地解决问题。
通过了解其中一种操作的方式来举一反三地对其他操作实现无师自通,比方说,你会解包,那么应该就会打包,你会增加应该也会删减,你会转换过来当然也该能转换过去,无非是点点鼠标,挪挪文件而已,如果你连PC上的基本操作都应付不了,那说这么多算我的错。[/color][/size][/font][/b]

小虎大哥 发表于 2009-7-13 13:26

[i=s] 本帖最后由 小虎1974 于 2009-7-13 21:24 编辑 [/i]

[b][url=http://www.it1862.com/redirect.php?goto=findpost&pid=684988&ptid=33016]1#[/url] [i]小虎1974[/i] [/b]
[size=5][color=red][b]下面我们来看看应用的例子:
NBH和NB之间的转换,使用工具:nbhtool.exe[/b][/color][/size]
[color=green][b]转换NBH为NB可以使我们一目了然地看清楚.NBH的ROM文件中到底包含了哪几部分,这种转换对整个NBH文件是一种模块的拆分,如图[/b]
[/color][attach]85075[/attach]
[b][color=green]双击打开[/color][color=green]nbhtool.exe后点一下“NBH转换为NB”,然后点一下中间的“解压NBH文件”[/color]
[attach]85076[/attach][/b]
[color=green][b]弹出文件夹,我们选择要解包的NBH文件的正确路径[/b]
[/color][attach]85077[/attach]
[b][color=green]找到后点中RUU_Signed.nbh文件,弹出对话框,需要我们选中解包后的[size=4]文件存放路径[font='"微软雅黑],找好后点“确定”[/font][/size][/color][/b]
[b][size=4][color=#000080][attach]85078[/attach][/color][/size][/b]
[color=green][b]我们可以看见界面下方有文件在快速滚动,最后弹出“完成”的提示窗,说明文件解包成功![/b]
[/color][attach]85079[/attach]
[b][color=green]然后我们进入已经解包的文件夹看看,发现只有一个NB文件,名为Windows.nb,从文件大小上看这就是我们的OS.nb,说明这个ROM里只包含OS部分。[/color][/b]
[attach]85080[/attach]
[b][color=green]同理,我们要把NB文件转换为NBH文件,可以如下操作:
打开nbhtool.exe,选中“NB转换NBH”见图[/color]
[attach]85081[/attach][/b]
[b][color=red]看看上图,怎么一下多了这么多选择框?
[/color][color=green]那是因为以NBH为扩展名的ROM文件转换为NB文件是解包,而由NB文件转换为NBH文件实际上是打包,既然是打包,当然可以把很多项打包到一起啊。大家可以看到,上面的选择框里有IPL,SPL,First Splash(开机第一屏) ,Second Splash(开机第二屏),OS,Radio等,这些文件如果要打包到ROM里,必须要全部是NB文件,并且必须要和上面的选择框一一对应,不然就会出大问题。
比如我们要选择把RADIO打包进ROM,必须要在Radio那个框里选择Radio.nb(文件名不一定非要叫Radio,但是扩展名一定是.nb)文件在PC里的正确路径载入,如果我们在别的框比如说在IPL选择框里选择载入的文件为Radio.nb文件的话,那就会出大问题,至于问题会有多大,我可以至少保证你刷完机死活都进不了系统。
一般情况下,我们并不推荐打包除OS之外的东西,毕竟包打得越大,危险性就越高,找对了NB文件的路径之后,我们就可以点击“生成NBH文件”了,这个时候照样会弹出对话框,需要我们选择所生成的NBH文件的存放路径,路径找好后点“确定”,就可以看见界面下方的文件在快速滚屏,直到提示“成功”那我们的NBH文件也就是ROM就生成了,余下的就是用刷机包把它刷入我们的PPC。
这种转换最大的好处是将所有的组件进行模块化打包到ROM里的,既然是模块化那么这些NB组件是可以自行替换增减的,那我们在定制的时候就可以自由地更换这些“零部件”了。
[/color][color=red]上面我们知道了NBH和NB之间的转换,但是貌似还是不能解决实际问题,ROM文件NBH是由OS转换的,但是OS如何转换为XIP,SYS,以及OEM和相关核心组件及驱动呢,如果解决了这个问题,那我们只需要找齐XIP,SYS,OEM及其它一些材料便能做出一道“好菜”了。[/color]
[/b][b][color=blue]别急,先抽根烟,让我慢慢道来,因为下面的这段是比较关键的!
[color=green]OS.nb要转换为我们最常见的材料一样需要再解包,我们称这种解包为DUMP(中文意:堆放,仓储),意思是将OS.nb里的文件一个个地拿出来进行重新转存,同样的,要解开OS,我们需要OSDUMP工具[/color]。
DUMP  OS.nb文件  使用工具:ROMCMD
ROMCMD是一款ROM制作的小工具,可以对ROM进行简单的解包,重组,和封包的操作,那在这里我们只利用它的DUMPOS功能。
[/color]
[color=green]我们打开解压后的ROMCMD文件夹,可以看到OSDUMP.bat这个自动批处理文件[/color]
[attach]85082[/attach][/b]
[b][color=green]然后我们将刚才转换来的windows.nb文件进行改名为OS.nb,对于大多数的批处理文件,对需要进行操作的文件名已经确定好了,所以如果不改名那这个OSDUMP.bat批处理文件是不认账的,因为它只默认处理文件名为OS.bat的文件。
接下来我们把改名后的OS.nb文件用鼠标拖动到这个OSDUNP.bat文件上面,电脑上就会弹出一个CMD的对话框了,紧接着我们会看到对话框里有文件在快速地滚屏,这表示OS.nb文件正在被解包,这个过程需要3到10分钟的时间,没关系,去喝杯茶或者点根烟。[/color][/b]
[attach]85083[/attach]
[color=green][b]时间不用太长我们便会看到CMD框最后自动消失了,那代表OSDUMP已经完成了对OS.nb文件的解包了,下面我们打开原来存放OS.nb文件的文件夹察看一下,我们发现文件夹里除原来的OS.nb之外又多出了几个文件:[/b]
[/color][attach]85084[/attach]
[size=4][b][color=green]从上图中我们可以看到多出的3个文件和一个dump文件夹,这4个就是由OS.nb解包而来的,其中有2个以.reg为扩展名的注册表文件,1个是
.txt文本文件,还有1个是dump文件夹。
这里还是解释一下,2个reg文件是原OS的注册表文件,user.reg是对应手机注册表里的User这一大项的,用于存放用户自定义的注册表项,而default.reg则是对应手机中的ROOT这一大项的,用于存放系统核心文件的注册表项,1个dump_MemoryMap.txt文件是用来记录原OS文件的地址段的,最后的Dump文件夹是我们OS里的所有文件,当然这其中是不包括XIP的。
从上面我们可以了解到,OS文件的原理不仅仅是将文件压缩到一起,它还把所有文件进行有机的排列组合,使各个文件之间互相衔接,以方便我们刷入机器以后能自由的调用,就像小孩在幼儿园一样,不仅仅是将小朋友(所有文件)放进去就行了,还要为他们编排座位和床位(地址段),还要记录他们的名字他们的性格以及特长等(注册表),然后才能更好地对他们进行管理。
好了,言归正传,我们通过DUMP OS文件得到了这么些东西,但是如果在这个基础上对OS进行修改却不是个容易事情,如果要删除或者更改哪几个文件,那就不仅仅只能挪动文件就行,还得改动他们的注册表,重组地址段,这个工程有点艰难,因为改动一旦出错那刷入机器之后就会出问题了,所以,我们的工作还得继续
[color=red]再继续处理这些文件之前,我们差点忘记了还有一个重要的事没做,那就是提取XIP.
[/color]下载能我们需要用到提取XIP的工具RomMaster,我们需要把OS.nb放进该文件夹:[/color][/b]
[/size][attach]85085[/attach]
[color=green][b]把OS.nb拖动到BuildXIP.bin.bat上,当然你也可以运行命令[size=3][font='"微软雅黑]“RomMaster -w 5 OS.NB  -x -o xip.bin”,[/font][/size]程序执行后我们就会得到xip.bin[/b]
[/color][b][attach]85086[/attach][/b]
[b][color=green]下面,我们需要把得到的xip.bin文件转换为文件的形式,我们使用DUMP命令,把xip.bin拖动到dumprom.bat上滚屏后就得到XIP文件[/color]
[attach]85087[/attach][/b]
[b][color=green]XIP部分已经出来了,接上面的工程,我们需要分解出SYS和OEM部分,上面的步骤我们已经DUMP出了OS.nb文件并得到了dump文件夹,这里面包含了SYS和OEM部分,余下的工作我们需要把它拆分为SYS和OEM。[/color][/b]
[attach]85088[/attach]
[size=4][b][color=green]在这里我们需要使用package_tool工具,打开[font='"微软雅黑]package_tool文件夹[/font][/color][/b][/size]
[attach]85089[/attach]
[color=green][b]我们双击上图中最后的一个应用程序PKGTool.exe就会打开如下程序界面[/b]
[/color][b][attach]85090[/attach][/b]
[b][color=green]然后我们再点“File—Open”,寻找先前的dump文件夹的路径,找到dump文件夹,再点“确定”,我们可以看到软件界面上有文件在执行,点完“确定”后,我们再点“Tools—Build Packages[/color][/b]
[attach]85091[/attach]
[color=green][b]等处理完成之后,我们进入dump文件夹看看[/b]
[/color][attach]85092[/attach]
[b][color=green]至此,一个完整的ROM被分解完成。
[/color][color=blue]这里需要说明一下,并不是每个ROM组成部分都是相同的,分解后得到的组件也并非都是齐全的,所以过程中可能会出现无法分解或组合的问题,根据每个ROM及每个工具的不同而异,此部分主要解释的是ROM编辑工具的用法,并非步骤性的东西。
至于ROM的打包和制作过程[/color][/b]

小虎大哥 发表于 2009-7-13 13:38

[i=s] 本帖最后由 小虎1974 于 2009-7-13 21:30 编辑 [/i]

[b][url=http://www.it1862.com/redirect.php?goto=findpost&pid=685003&ptid=33016]2#[/url] [i]小虎1974[/i] [/b]

[b][size=5][color=#0000ff]第三部分:ROM定制
[/color][/size][/b][size=4][b][color=black][color=green]本来说稍写得详细点,把每个定制步骤拆开来写,以方便其他机型的暂时无定制包可用的朋友,后来想想算了,本来就是写给初学者看的,谈到深一点的东西,熟手老手都可以做我的老师,时间关系,方便机油能尽快看到这个所谓的教程,所以直接把一键定制拿出来给大家理一理,请见谅,呵呵![/color][/b][/color][/size][size=5][font='"微软雅黑][color=blue]
[b][size=4] A、准备工作
[/size][/b][/color][b][size=4][color=green]PC端需要安装两个支持平台软件,一个是VC(Microsoft Visual C++),一个是NETCF(2.0和3.5都可,一般机器都已自带),PC端的XP,2000,98,VISTA都支持,其他平台未知。
安装成功后需要下载一套定制工具和OEM模板,定制工具现在最前卫的为[/color][/size][/b][/font][/size][b][size=4][font='"微软雅黑][color=black][color=green]myBUILDOS,貌似“独立小桥”在07年11月底发布的,这套工具可以说是完全抛弃了DOS环境操作,全Windows操作模式,人性化程度高,定制ROM只需要运行一个批处理然后按提示点“下一步”就可完成整个制作过程,所以被称为一键傻瓜制作,在这个制作工具之下,完全不用担心被如此多的步骤搞得眼花缭乱,头昏脑胀。[/color]
[/color][color=green]因原始的[/color][/font][font='"微软雅黑][color=green]myBUILDOS工具是没有根据机型进行调整的,所以建议大家针对自己的机型下载对应的[/color][/font][/size][/b][font='"微软雅黑][size=4][color=green][b]myBUILDOS工具,以免定制出的ROM不是自己机型的,搞得欲哭无泪。
工具下载完了,成形的材料还需要OEM包,OEM包是集成到ROM里的一些插件和软件,是必须的,如果定制包里没有OEM包或者OEM包里存在错误,那定制程序会报错,定制会进行不下去,这是[/b][/color][/size][/font][b][size=4][color=green]myBUILDOS已经规定好的。另外还需要SYS和XIP部分,这也是必须的,系统核心的部分没有,定制程序也会报错不让进行下去。
貌似说了通废话,下面我们来看看一个完整的定制包里有哪些东西:
工具包
OEM
SYS
XIP
[/color][/size][attach]85093[/attach][/b]
[size=4][b][color=#0000ff][color=green]看上图,很清楚地能看到整个定制包的结构,4个文件夹和4个文件,4个文件夹中没有XIP,因为XIP是放在ROM文件夹中的,注意文件夹的名称一定要是这样的,如果改名或者名称里多个符号少个字母都是不行的,XIP的名称建议大家直接写为“XIP”三个字母,当然也可以写为“XIP_ELF"或者“XIP_ELFIN”,主要看你是加强版的XIP还是普通版的了,SYS是通用的,不论定制加强的还是普通的。另外4个文件看文件名大家应该可以猜到有2个是批处理文件,分别对应ELF机型(普通S1)和ELFIN机型(加强S1),另外两个是分别针对ELF和ELFIN的匹配文件。
好了,现在开工,找齐SYS,XIP,OEM包,放到正确的位置(XIP放到ROM文件夹里),我们可以开始定制了。[/color]
[font='"微软雅黑] B、开始定制[/font][/color]
[color=green]如果你是定制加强版的,并且XIP也是加强版的,那么双击批处理文件ELFIN_BuildNB.bat[/color][/b]
[/size][attach]85094[/attach]
[color=green][b]请注意上图,在整个过程中不要将它关闭,如果关闭,定制就不会成功。
出现上图之后我们再稍等几秒就会出现[/b]
[/color][attach]85095[/attach]
[color=green][b]这里面有一些是必选的,而多部分是备选的,必选的部分前面必须要都打上勾,备选的部分根据你的需要打勾,需要集成进去的就打勾,在这里,必选项除了在后面标出来的外,字体包和输入法也是必选内容,如果必选的忘记选了,定制出来的ROM刷进机器后就会进不了系统或者进入系统后部分重要的功能用不了,比如电话功能。
把所有必选择的打上勾,备选的根据自己的需要打勾,然后我们就点击一下图中的那个三角符号(见图中红圈),代表生成ROM文件[/b]
[/color][attach]85096[/attach]
[b][color=green]点了之后可以看到定制程序开始处理文件了,并且进度条在前进,请注意红框的部分[/color][/b]
[attach]85097[/attach]
[color=green][b]然后开始创建注册表[/b]
[/color][attach]85098[/attach]
[color=green][b]最后提示完成[/b]
[/color][attach]85099[/attach]
[b][color=green]然后我们关闭这个已经完成的界面,我们可以看到CMD窗口在快速滚屏(上面说过定制过程中要让这个窗口一直存在着)
[/color][/b][attach]85100[/attach]
[b][color=green]滚屏完之后会弹出这个界面
[/color][/b][attach]85101[/attach]
[b][color=green]上面的”OK(5)“可以直接点OK,如果不点的话5秒钟的倒计时完之后,会自动打开刷机的界面[/color][/b]
[attach]85102[/attach]
[color=green][b]这时如果你想刷机就直接把空格里打上勾然后点“Next”,如果不想刷就直接点“Cancel”终止。[/b][/color]
[color=blue]至此整个定制过程完成,新的ROM已经生成,普通版的ROM在TOOLS\RUU之下,加强版的ROM在TOOLS\RUU\RUU之下,是以nbh为扩展名的。这时候就可以把它拿出来发布到论坛了,相当简单吧。
那么这个工具会用了之后,我们就可以到网上去找新的OEM软件包补充到我们的OEM文件夹里了,SYS和XIP从何而来呢,熟手可以直接从原生ROM里移植过来,新手也很方便的,直接拿来主义,用各位大侠们移植好的,让他们发布到论坛我们就可以直接下载下来放进工具包里定制属于自己的ROM了。
这部分就介绍到这里,后面我们会具体说明一下在这种定制模式下会出现哪些常见的问题,以及如何定制我们喜欢的界面,如何DIY自己喜欢的系统,又是如何制作OEM软件包供我们使用,尽量地做到万事不求人,岂不快哉![/color]

小虎大哥 发表于 2009-7-13 13:51

第四部分:ROM定制FAQ

[i=s] 本帖最后由 小虎1974 于 2009-7-13 21:34 编辑 [/i]

[b][size=4][color=#0000ff]第四部分:[/color][/size][/b][size=4][font='"微软雅黑][color=#0000ff][b]ROM定制FAQ
[color=green]ROM定制过程中会出现各种各样的问题,不胜枚举,在此本人只结合自己曾经遇到过的问题,以及根据自身浅薄的经验给出的分析和解决方法,希望给大家能带来点启发.[/color][/b][/color][/font]
[/size][size=4][color=#0000ff][b]  A、开始运行Buildos导致的报错[/b][/color]
[/size][b][size=4][color=#0000ff]具体表现在下图
[attach]85103[/attach][/color][/size][/b]
[color=green][b]报错原因大致有以下几点:
1、缺少必要组件导致的报错
比如:缺少SYS文件夹,缺少OEM文件夹,缺少ROM文件夹等
最常见的情况下,很多人在替换SYS和XIP部分时,把原来的SYS删除后忘记了放入新的SYS或者新的SYS没有放到模板的根目录,导致Buildos找不到可用的SYS,于是出现报错,见下图中,没有SYS文件夹部分,于是buildos就出现报错了。[/b]
[/color][attach]85104[/attach]
[b][color=green]完整的应该是:[/color][/b]
[attach]85105[/attach]
[b][color=#0000ff][color=green]大家对比一下上面的2张图就可以看出来了[/color]。
[color=red]2、新添加的OEM包错误或者不兼容导致的报错
[/color][/color][color=green]我们在使用模板的时候,很多情况下我们都要集成自己喜欢的一些软件,但是模板里没有这些软件的OEM包,怎么办呢,最方便的方法是我们直接去网上找来,然后放入OEM文件夹里,部分OEM包因为有机型的限制,所以定制的时候容易出现Builos报错,还有部分OEM可能本身存在错误,也导致Buildos出现报错。
所以我们在添加OEM包的时候一定要注意:[/color][/b][b][color=green]对于一次有很多OEM包要添加到模板的OEM文件夹的时候,最好采取谨慎的操作,一个个地添加,添加完后运行下Buildos.bat批处理,看看是否出现报错,然后再添加下一个,这样做能很好的避免添加后报错不知道错在哪个OEM包上,导致又要从头来一个个地排查,工作量很大。
[/color][/b][b][color=#0000ff][color=green]对于报错的OEM包,推荐暂时弃用,或者另找别的版本的再试。[/color]
[/color]  [color=blue]B、运行Buildos过程中出现的报错
[/color][color=green]具体表现在Buildos在生成文件的过程中跳出报错导致Buildos定制不能进行下去。例如:[/color][/b]
[attach]85106[/attach]
[b][color=#0000ff]1、因存在重复文件导致的报错
[/color][color=green]ROM定制是不允许有两个完全同名的文件存在的,否则就会出现报错,如上图的提示,说明文件重复了。这是最常见的报错。
在buildos选择组件的时候,很多只能是“只选其一”的,比如拨号面板,同名的软件等,如果把只选其一的选了两个或以上,就会出现报错。不同版本的同名软件或者同功能软件选了两个,就出现报错,比如两个QCellCore都选了,就出现报错。
报错了,我们可用回头检查,重新检查buildos里是否选择了相同的软件或组件,如果有,请只留一个,其他的把前面的勾取消掉。
部分同名文件存在于其他的文件中,而并不是由同名软件造成的,记住重复的文件名,我们就可以去提示的文件夹中将其删除掉,见下图:[/color][/b]
[attach]85107[/attach]
[b][color=green]红框中是该重复文件存在的路径
[/color][color=blue]2。生成注册表过程中导致的报错[/color]
[color=seagreen]同名文件的报错不存在了,buildos就会开始生成注册表了,见下图:[/color][/b]
[attach]85108[/attach]
[b][color=green]生成注册表过程中报错的情况比较多,并且从图中是不容易让你看出错在哪的,那么我们可以进入temp文件夹的log.txt中来查询了:[/color][/b]
[attach]85109[/attach]
[b]看红框[/b]
[attach]85110[/attach]
[b][color=green]看红框中的报错信息,蓝框中是报错所对应的RGU
如果你对整个OEM的RGU有GUID码的备份,那我们一眼就可以看出这个RGU存在于哪个文件夹中,去对应的文件夹中找这个注册表项,可能注册表指定的文件路径中不是以双杠"\\"来表示的,也可能是RGU尾部缺少空行,仔细检查后再重新运行一次Buildos即可。[/color]
[/b][size=5][color=blue][font='"微软雅黑]  [size=4][b]C、因定制过程出现问题导致ROM刷入机器后产生的错误
[color=green]这是大部分玩ROM定制的机油最容易出现的问题,也是最难排解的问题,定制过程都能顺利通过,但是定制出的ROM刷入机器后出现各种各样不正常的情况,导致机器不能正常使用,大体可分为以下几种情况:
[/color]1、开机卡屏[/b][/size][/font][/color][/size]
[size=4][b][color=green]ROM刷入后手机重启进不了系统设置界面,直接被卡在第一二三屏的界面不能通过,这就是我们常说的定屏现象.
卡屏现象分为两种:
[/color][color=blue]a、卡在第一屏[/color]
[color=green]上面我们已经学习了系统加载的顺序为[/color][/b][/size][size=4][b][font='"微软雅黑][color=green]IPL>SPL>OS,IPL是负责加载系统的底层应用程序,IPL加载过后,SPL将首先加载在系统中缓存的信息,比如拨号面板,字体包,输入法,图片等,而这两项加载过程如果出现不匹配或错误,将直接导致机器进入系统卡在第一屏.
IPL,主要负责加载系统底层的驱动和硬件的应用程序,驱动不是通用的,绝大部分都会有机型的限制,如果应用程序的驱动不匹配,或者不能被正常调用,IPL就不能实现正常的加载,开机就会直接进入三色屏或者直接卡在第一屏.所以,一定要注意的是系统驱动程序以及与其匹配的源文件,包括MUI文件,DLL文件等.
SPL在加载的顺序上是首先加载和底层驱动配套的应用程序以及需要缓存在系统中的信息文件,如果这些信息文件存在错误,比如字体包,输入法,在缓存过程中出错,就会直接导致卡在第一屏,至于错误出在哪,可能与系统底层的驱动不匹配,可能文件格式不正确,也可能是自带的DLL源文件不能识别,比如很多安装过手写输入法的机油就出现过装完重启被卡在第一屏的情况,总之,错误的原因是多方面的,建议大家使用已经测试过的OEM包,并非最新版本的OEM包就是最好的,大家要注意这个问题.
另外,需要说明一下的是,对于自行移植XIP和SYS的朋友,如果XIP移植不完整或者SYS移植过程中有部分文件未替换,一样会导致卡在第一屏,具体情况留到后面的移植部分中再详细说,所以卡第一屏的情况是比较复杂的,原因只能这么简略地谈谈,具体还在于大家在自己动手动脑地测试和排除才能找到实际原因所在。[/color]
[color=blue]b、卡在第二(三)屏[/color][/font]
[color=green]同理,卡在第二屏的情况指的是第二屏动画结束就定屏了,如同死机一般。这种情况一般是由于系统调用部分DLL出现错误导致的。SYS移植后注册表项可能和系统驱动里底层的DLL源文件名的定义或者路径的定义不一致,导致不能正常调用DLL,这种情况下需要手动更改DLL的路径指向或者更改DLL在注册表里所定义的文件名,让注册表能正常调用DLL,另外动画图片的尺寸不正确也可能导致卡在第二屏,所以推荐大家在自行移植的时候注意这个问题,特别是注意底层驱动对应的DLL文件名及路径。
卡在第三屏也是同理,在这里有两种情况,一是进入第三屏直接卡住,一种是跳出调整界面的文字提醒的时候卡住,屏幕触摸无反应,前面一种情况可能和Touch.dll这个文件有关,部分注册表的定义可能会被定义为Hwtouch.dll,文件名不能和注册表对应导致无法正常调用,后一种情况可能和触摸的Touch.dll有关,也可能和输入法的注册表定义正确与否有关,总之原因比较多,。一切在于靠自己的经验摸索着去解决。
[/color][color=blue]2、程序或软件不能正常调用[/color]
[color=green]表现在很多方面,这里只举几个例子来说明[/color]
[color=red]a、该程序找不到相应的组件,或者其证书验证不能通过,或提示为一个非本设备可使用的组件[/color]
[color=green]这种情况一般为相应的exe程序没有被定制进去,或者缺少相应的DLL组件导致程序不能正常打开或运行。这个大家可以去Windows下找找,看有无源程序或相应的模块存在,如果没有则是未定制进去,如果存在源程序,就可以尝试点击它打开,如果依然打不开则说明该软件OEM包可能并不支持该机型,使用在该设备上不能生效。[/color]
[color=red]b、设备的“程序”或“设置”列表里未出现相关的快捷图标[/color]
[color=green]在排除804MUI文件出错的情况下,“程序”里未出现快捷方式和定制ROM时对该软件的快捷方式的定义有关,在该软件的所指定的快捷方式不正确或者路径出错导致的,我们可以找到该软件OEM包里的initflashfiles.txt,打开它查看一下所定义的快捷方式是否指向了“程序”文件夹;而“设置”项里缺少快捷方式则直接与注册表项的定义有关,我们可以打开HKEY_LOCAL_Machine\ControlPanel\下,[font='"微软雅黑]看看所定义的软件名称与[/font][/color][/b][/size][font='"微软雅黑][size=4][color=green][b]HKEY_LOCAL_Machine\ControlPanel\MyCpl下的软件名称是否一致,然后再查看下是否设置了隐藏,该软件的Group项的键值是否在0到2的范围内以及是否设置了Hide为1的双字节值。
[/b][/color][/size][/font]

小虎大哥 发表于 2009-7-13 14:13

[i=s] 本帖最后由 小虎1974 于 2009-7-13 21:44 编辑 [/i]

[size=4][b][color=#0000ff]3、程序界面出现显示错误
[/color][color=green]一般出现在拨号面板,输入法,以及字体上面,部分软件界面会出现界面大小及界面字体不正常的现象。
拨号面板最容易出现的是显示错误,面板定制进去变成白板或者直接就打不开,这个原因也比较多,我们可以采取排除法来找原因
首先,我们一定要注意这个拨号面板是针对VGA还是QVGA的,因为显示屏的分辨率不同会导致面板成为白板或出现其他显示不正常的情况;在此,还是对VGA和[font='"微软雅黑]QVGA进行下简单解释吧:[/font][/color][/b][/size][font='"微软雅黑]
[size=4][color=red][b]VGA[/b][/color][/size][/font][size=4][b][color=red][font='"微软雅黑](Video Graphics Array)全名[/font][/color][color=red][font='"微软雅黑]视频图像阵列[/font][/color][font='"微软雅黑],[color=green]是IBM于1987年[/color][/font][font='"微软雅黑][color=green]提出的一个使用模拟信号的电脑显示标准,这个标准已对于现今的个人电脑市场已经十分过时。即使如此,VGA仍然是最多制造商所共同支援的一个低标准,个人电脑在加载自己的独特驱动程式之前,都必须支援VGA的标准,[/color][/font][/b][/size][b][font='"微软雅黑][size=4][color=green]VGA在指定色版颜色时,一个颜色频道有6个bit,红、绿、蓝各有64种不同的变化,因此总共有 262,144 种颜色。在这其中的任何 256 种颜色可以被选为色版颜色,通常情况下,VGA的分辨率点阵为640×480,但是由于采用了Windows Mobile系统的缘故,致使VGA的显示被限制在65000色(16位色)之内。[/color]
[color=red]QVGA [/color][/size][/font][color=red][font='"微软雅黑][size=4]([/size][/font][/color][size=4][color=red][font='"微软雅黑]Q[/font][/color][color=red][font='"微软雅黑]uarter [/font][/color][color=red][font='"微软雅黑]VGA)[/font][/color][/size][font='"微软雅黑][color=red][size=4]意指四分之一的VGA视频图像阵列[/size][/color][/font][size=4][color=black],[color=green]VGA的阵列为[/color][/color][/size][size=4][color=green][font='"微软雅黑]640×480,除以4后得到的阵列模式为[/font][font='"微软雅黑]320×240,QVGA的点阵数较VGA减少到了四分之一,换句话说,在同样尺寸的液晶屏上进行视频图像显示输自然就比不上VGA细腻、清晰和逼真了,[/font][/color][/size][/b][font='"微软雅黑][size=4][b][color=green]但是,不管运用哪种显示分辨率都有其好处所在,VGA分辨率高,但是因为其点阵队列较密集些,所以在显示图像上需要加载的时间也会较QVGA长很多,对CPU的处理频率也要求更高,在没有配备独立显卡的情况下,同样主频的CPU在同样尺寸的VGA和QVGA屏上处理图像显示的时候,QVGA屏在收到指令后显示图像的速度较VGA屏快得多,这就是为什么HTC在使用德州仪器201主频的CPU上只使用QVGA屏的原因,如果使用VGA的话,打开图片或者图像文件的过程将会成为漫长的等待;而若使用VGA屏的话,要想图像和图片显示速度提高,只能通过提高CPU的主频,或者配备独立的硬件显卡,否则,就会如同“小牛拉大车”,所以,要华丽和眩目是需要硬件配备付出代价的,而这些代价的付出将直接连带着其他配件性能的相应提高,比如更强的电源管理能力和更大容量的电池续航能力。
[/color][color=green]总而言之,使用Q屏最大的好处就是在较低的硬件配备上可以获得同样快速的操作体验,缺点就是屏幕色彩不够华丽和丰富。
解释完这个之后,我们应该明白了一个道理,如果把V屏使用的拨号面板应用到Q屏之上,就会出现显示不正常。所以大家一定要看清楚拨号面到底是Q屏之下的还是V屏之下的。[/color]
[color=red]拨号面板[/color][/b][/size][/font][size=4][b][color=green]出现不能正常显示的另外一个重要原因还和其搭配的DLL有关,众所周知,拨号面板的“拨号”功能是通过调用DLL来实现的,如果DLL缺失或者DLL指向错误,拨号面板一样不能正常显示,因为缺乏必要的DLL的显示支持,所以我们可以经常看到部分拨号面是需要连带集成相应的智能拨号插件才能正常显示的,所以大家在集成拨号面板的时候也要注意这个问题。
下面说说字体包
[/color][color=red]字体包[/color][color=green]是系统调用的显示字体,有人喜欢宋体,有人喜欢雅黑,也有人使用别的字体,这里说一下,Q屏之下宋体是最清晰的字体,因为它和屏幕的显示模式是相同的,同样使用了矢量点阵的模式在显示,所以宋体是不需要开启任何辅助就能直接显示的。而别的字体比如雅黑,这是微软根据其英文字母在PPC之下的显示而创建的,对于汉字来说,显示很模糊,纵然开启了所谓的效果渲染ClearType,一样得不到改善,因为这种渲染同样是基于英文字母的,很遗憾,微软没有为Windows Mobile系统研发汉字效果渲染技术。
闲话到此,我们来看看字体会出现哪些常见问题
[/color][color=blue]1、汉字字体显示为“口口”等方框模式[/color][/b][/size][font='"微软雅黑]
[size=4][b][color=green]这种情况应该是大家经常碰到的情况;大家知道,系统要调用一种字体是有几个前提条件的:
[/color][color=red]a、系统里存在该字体文件,一般在 Windows\ 下,部分可以放在 Windows\Font\下[/color][/b][/size][/font]
[b][size=4][color=red]b、该字体文件的路径是正确的,就是说系统能根据你指定的路径找到它,在你指定的路径之下找不到当然就无法调用了[/color]
[color=red]c、字体文件名是正确的,比如“msyh.ttf",不然找到了该路径找不到这个文件名一样调用不了[/color]
[color=red]d、字体文件的字体名称是正确的,不如"微软雅黑"[/color]
[color=red]e、字体的映射是正确的[/color]
[color=green]以“微软雅黑”为例,字体映射就是把系统原来的字体全部改变为“微软雅黑”,比如你安装的软件原本是宋体的,比如系统里的字母通常为Tahoma字体,你需要把这些字体全部改为调用“微软雅黑”来显示,如果你不定义原来软件里宋体为调用“微软雅黑”,那么系统就会寻找宋体来显示,但此时你没有集成宋体,那该软件里的字体就会变成“口口”了。
字体映射一般是字体显示为“口口”的最大病因,在集成字体之前,请打开你的字体OEM包里的RGU注册表,请注意这项下面的内容:
[/color][color=red][HKEY_LOCAL_MACHINE\Software\Microsoft\FontLink\SystemLink]
[/color][color=green]在这项之下我们会看到有很多字体,比如"细明体"、 "新宋体"、"Times New Roman"等,这些就是系统里可能出现的字体名,需要把这些字体全部换成调用你现在的新字体比如“微软雅黑”,在指定路径的时候请一定记得路径在RGU里是以双斜杠“\\”来表示的,集成到手机注册表里才会变成单斜杠“\“,我们可以这样来表示:  "Times New Roman"="\\Windows\\msyh.ttf,微软雅黑",意思是说,如果系统要调用[/color][/size][size=4][color=green][font='"微软雅黑]"Times New Roman"这个字体的时候,它就会指向在 \Windows\这个路径之下的字体名为“微软雅黑”的“msyh.ttf”的这个文件来调用,如果你不这样指定,那么系统在调用[/font][font='"微软雅黑]"Times New Roman"这个字体的时候[/font][font='"微软雅黑]会自动寻找这个字体的文件来调用,如果找不到,[/font][/color][/size][/b][size=4][b][color=green][font='"微软雅黑]这部分的字体就会出现“口口”。
在通常的情况下,软件OEM包里的字体会默认为 “Tahoma",Tahoma是系统里默认用来显示英文字母的字体,如果显示在汉字上,就会出现大小不一甚至显示模糊线条发虚的情况,我们可以看到很多字体是被指定默认为调用“Tahoam”的,比如 :
"细明体"="\\windows\\tahoma.ttf,Tahoma"
"新细明体"="\\windows\\tahoma.ttf,Tahoma"
"新宋体"="\\windows\\tahoma.ttf,Tahoma"
那么在这种情况下,我们只需要重新定义一下"Tahoma"这个字体就OK了,比如: "Tahoma"="\\Windows\\msyh.ttf,微软雅黑",那么在系统默认指定调用 [/font][font='"微软雅黑]"细明体"、[/font][font='"微软雅黑] "新细明体"、[/font][font='"微软雅黑] "新宋体"这些字体的时候,它会指向“Tahoma”这个字体,而[/font][font='"微软雅黑]“Tahoma”[/font][font='"微软雅黑]这个字体又指向了[/font][/color][/b][/size][font='"微软雅黑][size=4][color=green][b]msyh.ttf,微软雅黑",所以,实质上,中间转了一道弯,系统还是在调用“微软雅黑”这个字体。
另外,我们还要注意这个注册表:[HKEY_LOCAL_MACHINE\Software\Microsoft\Inbox]
"RichEditHostFontFace"="微软雅黑"
这个注册表是定义系统里默认的字体的,大家一般喜欢把这个默认字体定义为你要装的新字体名比如“微软雅黑”,这样定义道理上来说是没错的,但是,我们在调解字体大小的时候,实质上是以“Tahoma"这个字体名来默认的,如果指定系统字体为“微软雅黑”,那么部分字体的调节是不能生效的,换句话说,系统里会出现字体大小不一的现象,不如前两天有机油问到我关于2DFLO“联系人"里的字体很小,几乎缩到一起去了,还有部分软件界面里的字体看不清楚怎么调都调不大,所以请大家在定义这个默认字体键值的时候,最好定义为:"RichEditHostFontFace"="Tahoma"这样,那么系统里的字体就不会出现大小不一模糊不清的情况了,并且如果你想改变字体的大小,直接可以去下面这个注册表路径里去修改就OK了:[HKEY_LOCAL_MACHINE\System\GDI\V1\FontAlias]
[/b][/color][/size][size=4][color=blue][b]2、字体显示为乱码
[color=green]显示不是“口口”,出现诸如“-%&*#”这类的东东,甚至显示为日文符号或者不能显示是空白,这种情况是由于所定义的字体改变字型所导致的,当然在拨号面板里出现的例外(这是拨号面板的问题),一般出现在部分软件的符号里,这种情况的原因是因为新装的字体包在定义字体调用的时候没注意到符号的调用,本人曾经碰到过安装雅黑粗体的一位机油有过这种情况。
部分字体包不能自行加大字体和加粗字体,否则符号和部分字体将不能被识别,比如擅自改动了以下项:[/color]
[color=darkorange][HKEY_LOCAL_MACHINE\System\GDI\SYSFNT]
[/color][/b][/color][/size][/font][font='"微软雅黑][size=4][color=darkorange][b]"Ht"=dword:00000384
"WT"=dword:00000190
[/b][/color][/size][/font][font='"微软雅黑][size=4][color=darkorange][b][HKEY_LOCAL_MACHINE\SYSTEM\GWE\OOMFnt]
[/b][/color][/size][/font][font='"微软雅黑][size=4][color=darkorange][b]"Ht"=dword:00000384
"WT"=dword:00000190
[/b][/color][/size][/font][font='"微软雅黑][size=4][color=darkorange][b][HKEY_LOCAL_MACHINE\SYSTEM\GWE\Menu\PopFnt\BarFnt]
[/b][/color][/size][/font][font='"微软雅黑][size=4][color=darkorange][b]"Ht"=dword:00000384
"WT"=dword:00000190[/b][/color][/size][/font][font='"微软雅黑]
[/font][font='"微软雅黑][size=4][color=darkorange][b][HKEY_LOCAL_MACHINE\SYSTEM\GWE\Menu\PopFnt]
[/b][/color][/size][/font][size=4][color=darkorange][b][font='"微软雅黑]"Ht"=dword:00000384
"WT"=dword:00000190[/font]
[/b][/color][/size][size=4][color=darkorange][b][font='"微软雅黑]以上项是改动字型的高度和宽度的,汉字因为是笔画点阵结构,所以改动会生效,但是符号和字母如果在调用相同的字体的时候就会出现显示为乱码,这是因为改动后在点阵上不能支持而导致的,所以请大家注意这个问题,擅自改动有可能会导致不能正常显示符号和字母。如果硬要改动不可,那么请将字母和符号映射到其他的字体上,字母和符号的在注册表里的具体映射项为:
"Arial"="\\Windows\\Tahoma.ttf,Tahoma"
"MS Sans Serif"="\\Windows\\Tahoma.ttf,Tahoam"
"Courier New"="\\Windows\\Tahoma.ttf,Tahoma"
"Nina"="\\Windows\\Tahoma.ttf,Tahoma"
或者直接在[HKEY_LOCAL_MACHINE\System\GDI\V1\FontAlias]下进行定义,将键值直接定义为调用其它字号的字体,这里就不罗嗦了。[/font]
[/b][/color][color=blue][b]3、字体越界
[/b][/color][color=green][b]貌似很多机油在碰到这种情况之下只能对字体进行弃用,最容易越界的几个地方:"开始"-"设置":"时钟"的"闹钟"界面 、"关于"、"菜单"、"屏幕"、"电源"里,容易出现"剃头"(字体头部被削掉了)和"切尾"(字体脚部被切掉了)的现象。
所有的越界几乎都和字号变大有关。[/b][/color][/size][size=4][color=black][b][color=green]PPC系统字体的字号默认是9号字,所以对话框就专门为9号字体为标准订做的,如果字体字号改得过大(一般来说超过了13号),就会超出对话框的限制,从而出现上面的"剃头""切尾"的情况。
所以我们在改字体大小的时候一定要注意,其他地方的字体大小可以改,但是涉及到对话框里的字体项请不要改大,对话框里的字体最大的显示限度是13号,如果改为14号,一般情况下(未修改对话框大小的情况下)就必定会越界,下面我们来看看系统GDI字体里的字号定义:[/color]
[color=darkorange][HKEY_LOCAL_MACHINE\System\GDI\V1\FontAlias]
"SC_Song:14"="Tahoma:14"
"SC_Song:10"="Tahoma:14"
"SC_Song:12"="Tahoma:14"
"SC_Song:18"="Tahoma:14"
"SC_Song:16"="Tahoma:14"
"SC_Song:15"="Tahoma:14"
"MS Shell Dlg:8"="Tahoma:14"
"System:14"="Tahoma:14"
"System:8"="Tahoma:14"
"Tahoma:16"="Tahoma:-15"
"Tahoma:-16"="Tahoma:-15"
"Tahoma:14"="Tahoma:14"
"MS Sans Serif:-13"="Tahoma:14"
"Arial:-14"="Tahoma:14"
"version"=dword:0009000c
"Tahoma:17"="Tahoma:14"
"Tahoma:18"="Tahoma:14"
"Tahoma:20"="Tahoma:14"
"Tahoma:-11"="Tahoma:13"
"Tahoma:-10"="Tahoma:13"[/color][/b][/color][/size][font='"微软雅黑]
[/font]
[size=4][b][font='"微软雅黑][color=blue][color=darkorange]"Tahoma:-9"="Tahoma:14"
[/color][/color][color=red]注意上面的键值:[/color][/font][color=red][font='"微软雅黑]"Tahoma:-11"="Tahoma:13",[/font][font='"微软雅黑]"Tahoma:-10"="Tahoma:13",这两项是直接关联到对话框里的字号的,如果你强行改为14,或者在13前面加上一个“-”号,[/font][font='"微软雅黑]那么字体[/font][/color][/b][/size][font='"微软雅黑][size=4][color=#0000ff][b][color=red]就会出现越界,甚至导致对话框也跟着越界(对话框有部分跑出屏幕外面去了)。[/color]
[color=green]具体的字体大小[/color][/b][/color][/size][size=4][color=green][b]可以随便改,但是一样不要改得超过16,否则一样会越界,如果想改大系统的字体,你可以添加[/b][/color][/size][/font][font='"微软雅黑][size=4][color=green][b]"Tahoma:-12"="Tahoma:13",请注意别在13前面添加"-"号,虽然你想让英文和汉字的字号跟着一起变的心理是好的,但是要说的是雅黑字体之下的英文会导致你的对话框极度越界(几乎一半跑到屏幕外面去了)。
有个最头疼的问题是,如果将[/b][/color][/size][/font][size=4][b][color=green][font='"微软雅黑]"Tahoma:-12"="Tahoma:13"加入,"时钟"里的"闹钟"界面的"星期六"你很可能就看不到了,或者你最多只能看到是" 星期六"的"六"字的一半,另一半越界了,有些问题就是这么恼人,就如同前些天至胜兄(hmh88)的10级背光驱动一样,换个新核心定制进去几乎一半跑到屏幕外面去了。
遇到这种情况要么直接把字体改小点或弃用显示不太正常的软件,要么直接手动修改对话框,当然前提是你只有那么很少的两处越界,当然你不怕麻烦也可以全部改一遍,谁叫你喜欢系统大字体呢
下面介绍下修改对话框的方法[/font]
[/color][/b][/size][color=black]
[/color][size=4][color=green][b]对话框一般存在于exe文件或MUI文件之中,所以我们需要下载能打开这些类型文件的软件,在这里我们可以使用ResHacker 或者eXeScope等(PS:这些软件网上到处是,Google一下大把的,不要再找我要了)[/b][/color][/size][b][color=green][size=4],我在这里我就分别说下吧,看样子还是得上图:
用[/size][font='"微软雅黑][size=4]ResHacker[/size][/font][/color][/b][b][size=4][color=green]打开如下
[/color][/size][attach]85111[/attach][/b]
[b][color=green]请注意上面红框的部分为对话框的大小定义,前面160是宽度,后面的168是高度,蓝框里的是字体大小。
再用[/color][/b][size=4][font='"微软雅黑][color=blue][b][color=green]eXeScope打开:[/color]
[attach]85112[/attach][/b][/color][/font][/size]
[color=red][size=4][b]说了这么多,其实说的都是些最常见的问题,也是些基础性的东西,而在实际的ROM定值过程中遇到的各种问题还会有很多很多,只是希望大家能自己摸索,不断完善。[/b]
[b]终于搞定了,辛苦啊。。。[/b][/size][/color]

游戏人生 发表于 2009-7-13 14:23

看了还要回

cyssddy 发表于 2009-7-13 15:11

俺的那个神啊!!

szeas 发表于 2009-7-13 15:51

不错,强烈加分支持小虎,HD的机友有福了,可以尝试自己动手定制属于自己的ROM

朽木头 发表于 2009-7-13 16:04

:o:victory:支持!辛苦了

qindy 发表于 2009-7-13 16:15

:dizzy::dizzy:伟大的小虎,叫我写扫盲我还真宁愿死了得了,抽时间我也去爱疯区写份扫盲。

liqiang847682 发表于 2009-7-13 17:15

强烈支持一下小虎!
太强悍了!

小虎,咱耐你嘅;P

liguosheng 发表于 2009-7-13 17:18

买不起HD啊

爱热闹的猫 发表于 2009-7-13 18:21

额的神呀,这么厉害

[attach]85126[/attach]

酷客网络 发表于 2009-7-13 23:21

感谢小虎的详细教程!
估计会有很多人需要!

太初 发表于 2009-7-15 16:54

[i=s] 本帖最后由 太初 于 2009-7-15 16:55 编辑 [/i]

谢谢小虎哥。
我早就想找个完整的教程了。

最好能提供个 全套ROM制作工具的链接。
谢谢。

ntfsgm 发表于 2009-7-17 13:56

辛苦了

v2pipi 发表于 2009-7-19 17:47

lz 截图里面有  六月天空的文件夹哦。

空闲时 看Y片??? 呵呵

zyy3152 发表于 2009-7-21 22:20

谢谢!!!可惜99%的ROM都已经加密,根本解不开!:dizzy:

zjfsdick 发表于 2009-7-22 23:58

就是,到了XIP.Bin的地方,就是出不来XIP.bin

zhangchizh 发表于 2009-7-23 13:33

抽时间我也去爱疯区写份扫盲。

页: [1] 2 3 4 5 6 7 8 9 10

Powered by Discuz! Archiver 7.0.0  © 2001-2009 Comsenz Inc.