codecamp

修改BIOS全屏开机画面

打造自己的品牌机
—— 一起来修改BIOS全屏开机画面

本文作者为 安徽 张雁 版权为《电脑报》报社所有,不得抄袭或转载。

资源下载[下载OEM LOGO图片及相关程序]

 前几期刊登了数篇关于修改BIOS LOGO的文章后,引起了广泛关注。如果你已领略了修改BIOS LOGO所带来的快感的话,是不是想再试试修改最过瘾、最精彩、最令人兴奋的像品牌机一样的全屏开机画面(下称“OEM LOGO”)?本篇就将详细地介绍修改OEM LOGO的每一步骤及相关知识。好了,还等什么,让我们一起来打造自己的品牌机吧!

你的BIOS支持OEM LOGO吗?

  你的BIOS支持OEM LOGO吗?这个问题也许会让你感到失望,但这是修改OEM LOGO首先应解决的问题。你也许会摇摇头说:“我的主板(或是BIOS)还是X(X<=3)年前的,不可能支持”。 先别肯定,笔者的扳子是华硕TX97LE(BIOS是98年3月17日的),起初也认为不可能支持OEM LOGO,但经过一串冒险的实验后(是拿BIOS做实验呀),证实笔者的BIOS也支持OEM LOGO。而通过下面的实验和分析,你也许也会有新的发现棗原来我的BIOS也支持OEM LOGO 呀。

实验一

  先用PFLASH(笔者用的是华硕板子自带的)将BIOS数据备份到文件中(例如BIOS.BIN),键入命令:CBROM BIOS.BIN /D(只有1.26以上版本的CBROM才有此功能),此时显示BIOS文件信息如下:

 No. Item-Name Original-Size Compressed-Size Original-File-Name
  0. System BIOS 20000h(128.00K) 12F16h(75.77K) original.tmp
  1. NCR ROM 08000h(32.00K) 04E33h(19.55K) pci32.rom
  2. EPA pattern 00642h(1.56K) 002A1h(0.66K) awardepa.epa

  Total compress code space = 1B000h(108.00K)
  Total compressed code size = 17FEAh(95.98K)
  Remain compress code space = 03016h(12.02K)

  从第4行可以看到已压缩的EPA格式文件,但却找不到BMP文件的半点踪影。从第5?/FONT>7行可以看出,BIOS文件最大压缩空间(即“Total compress code space”值的大小)为108K,已用95.98K,还剩12.02K。
  如果我们用以前文章中提到的方法分析上面的信息,从BIOS文件中仅剩12.02K剩余压缩空间和找不到BMP文件格式这两点就可以“肯定”地判断笔者的BIOS不支持OEM LOGO。但事实真的如此吗?让我们再来看——

实验二:

  笔者随便做了一张640x480大小16色的BMP文件,上面画了几个字,大小为145K,文件名为GOLDWAVE.BMP。首先“强行”将BMP文件植入BIOS.BIN中,键入命令:CBROM BIOS.BIN /LOGO GOLDWAVE.BMP。让笔者惊喜的是,这一过程顺利地进行了,并没有出现错误信息。接着键入:CBROM BIOS.BIN /D,此时显示BIOS文件信息为:

No. Item-Name Original-Size Compressed-Size Original-File-Name
……
3. LOGO BitMap 2443Ch(145.06K) 009B5h(4.43K) goldwave.bmp
……

  从多出的一行可以看出,植入的BMP文件Original-Size(原始文件大小)为145.06K, Compressed-Size(压缩后文件大小)为4.43K。咦,原来BMP文件是经过CBROM这个程序压缩了的,怪不得小小的BIOS文件能装下145.06K的“庞然大物”。
  向BIOS文件植入图片这一过程已顺利完成,但能否就此说笔者的BIOS完全支持OEM LOGO呢?现在只有通过更新BIOS来证明了。
  笔者用PFLASH小心地将也植入图片的BIOS.BIN烧录到ROM中,怀里紧抱着从朋友那里借来的板子(以防万一),嘴里喊着“阿门”,惴惴地按下了RESET。
  随着一声清脆的喇叭响,屏幕顶端显示出熟悉的PCI显卡检测信息,这时笔者已经感觉到BIOS没有出致命性的问题。随后屏幕一闪,上面显示一堆颜色很乱东西(即后面要说的“花屏”),仔细一看,原来是开始时“随便”画的图片,不过已面目全非了,再随后就是蓝天白云……
  终于松了一口气,实验结果完全可以证明笔者的BIOS支持OEM LOGO。从上面的和后来的若干次实验,可以得出以下结论:

  1. 并不能以原BIOS文件中是否有BMP格式文件来判断BIOS能否支持OEM LOGO(这也许是许多人已犯过的错误)。

  2. 图片是经过压缩后才植入BIOS中的,而不是直接植入的,所以并不能用图片文件的大小来判断其经压缩后在BIOS文件中所占的空间,而是以图片中图形和色彩的多少(这与压缩算法有关)来判断。例如,同为16色640x464大小,文件大小为145K的两张BMP图片,一张上面画了几笔,经压缩后仅0.52K;而另一张用了多种颜色,画了多个图形,经压缩后竟达8K。

  3. 由结论2也可推出:使图片(压缩后的)变小的方法是:原图片尽量使用少的颜色和简单的图形,而不仅仅是改变原图片的像素大小。

  4. 图片不论是大于或小于640x480像素,都将以平铺的形式显示OEM LOGO(与WIN9X桌面背景平铺一样),并且在OEM LOGO底部还有640x16像素用来显示提示信息(即:Press [TAB] to Show POST screen,[DEL] to enter SETUP),而无论图片大小,此信息始终显示,所以创建640x480像素的图片是没有必要的,而640x464像素是最合适的(这样也可以更好地控制满屏显示的效果)。

  5. FLASH ROM(闪存,即存储BIOS的地方)的容量有1M和2M的,而BIOS文件大小一般情况下也有两种,即126K和256K。假设在BIOS支持OEM LOGO的情况下,那么并不是以FLASHROM的容量和BIOS文件大小来判断BIOS是否能装下图片文件(压缩后的),而是以BIOS文件剩余的压缩空间来判断(即“Remain compress code space”值的大小)。例如:图片经压缩后为10K。那么即使你的FLASH ROM容量为2M,BIOS文件最大压缩空间为210K,但BIOS文件中仅剩9K压缩空间,也照样装不下图片;而你的FLASH ROM容量为1M,BIOS文件最大压缩空间仅仅108K,但还剩11K压缩空间,那么照样能装下图片。当然,一般情况下BIOS文件越大,其剩余压缩空间就越大(一般为60?/FONT>120K),而BIOS文件越小,其剩余压缩空间也就越小(一般为3?/FONT>30K)。

  6. 如果修改OEM LOGO后,出现“花屏、变色”而非“黑屏或无任何显示”的现象,那么并不会影响系统安全,也不是你的BIOS不支持OEM LOGO,相反你的BIOS完全支持OEM LOGO。之所以出现“花屏、变色”的情况只是与图片有关(如何修改图片将在后文介绍),而非BIOS是否支持及BIOS空间大小的问题。

  7. 如果在“CBROM xxx.BIN /LOGO xxx.BMP”向BIOS文件植入图片这一过程出错,那么可能的原因有两种:一种是BIOS不支持OEM LOGO (笔者测试了从96到99年的几十种BIOS文件,目前还没发现这样的错误信息),解决方法只能是你就此作罢了;另一种是BIOS文件中的剩余压缩空间小于图片压缩后的大小,解决方法是按结论3中的方法减小图片大小(一般256K的BIOS文件不会出现这种情况)。

  8. 由于修改OEM LOGO只是CBROM这个程序向BIOS文件中加入图片数据及调用它的程序代码,并不会修改BIOS的核心模块(包括BOOT BLOCK),所以结论7中的步骤如果没有出现错误的话,那么即使你的BIOS不支持OEM LOGO,也不会导致BIOS致命性的错误(开机无任何反应)。当然并不排除由于操作失误和其他原因而导致的失败。

  为证实以上几点结论的可重复性,笔者在另一台VX(BIOS是97年4月的)板子上实验通过。由于条件限制,不能在更多的机子上做验证性实验,所以以上的结论可能会在不同的情况下有所偏差,但在大数情况下是适用的(至少是适用于TX及以后的扳子)。
  你的BIOS支持OEM LOGO吗?我想现在你的答案已很清楚了,但答案是什么只能由你自己决定,笔者不会煽动你修改BIOS,毕竟这是计算机操作中最危险的事(就看谁有“运气”亲身体验了),导致的任何损失,笔者也不会负责(谁在扔鸡蛋!)。

 创建LOGO图片

  在本文写之前,一定有不少朋友已尝试了修改OEM LOGO,但也许会发现“花屏”或“变色”(即画的是这种颜色,而显示时却是其他颜色)的现象,使自己精心设计的LOGO面目全非。而许多朋友认为只要用绘图程序的“另存为16色位图”就可以创建LOGO图片了,其实事情并没有想象的那么简单,问题也就出在这LOGO图片上。所以在创建图片之前,先了解一下LOGO图片的文件格式是必要的。
  在20期的《修改BIOS LOGO FAQ》一文中,曾提到这种文件格式是“不知名的二进制格式文件”,之所以这样认为,我想是用了“CBROM XXX.BIN /LOGO EXTRACT”提取BIOS文件中的图片这一功能,但这一功能提取出的图片文件与原来植入BIOS的图片文件完全不同(虽然文件大小相同)。提取出的文件确实是“不知名的二进制格式文件”, 但植入BIOS的图片文件却是标准的16色“索引”位图文件。
  其实位图文件(BITMAP,即BMP文件)从文件格式上分有两类,一类是我们熟悉的“RGB”格式,它是用“R、G、B”红、绿、蓝三种颜色来表示一个点的颜色,例如某一点为蓝色,那么就用代码“00 00 FF”表示这一点的颜色。由于RGB三个量中每个可取256种值(0到FF),所以最多可显示16M(256^3)种颜色。而另一类就是“INDEX”(索引)格式,这种格式的文件首先在文件头(从3CH开始)建立颜色表(可用PHOTOSHOP等程序查看颜色表),然后用颜色表中的颜色代码来表示每一点的颜色。例如颜色表中第15位颜色为蓝色,某一点的颜色也为蓝色,那么就用0F(十六进制)表示这一点的颜色,而不是用RGB格式中的“00 00 FF”来表示。“索引”位图最多只能显示256(2^8)种颜色。
  上面简单地介绍了位图文件的格式,那么“花屏”到底是什么原因呢?原来一般的16色索引位图颜色表中的颜色可以是16M种颜色中的任何16种,而LOGO图片却是标准的16色索引位图文件,它的颜色表中只能是即定的16种颜色,如果颜色表中的颜色不是这16种或超出了这16种,那么就会引起显示时的“花屏”现象。从原因上看,解决的办法就很简单了,即将LOGO图片创建成标准的16色“索引”位图文件(可用“画图”程序的另存为“16色位图”完成)。
  “变色”的原因相对于“花屏”来说就没有那么简单了,由于不知道BIOS是怎样显示LOGO图片的(和一般的程序肯定不一样),所以也就不能从根本上了解原因,但一个有趣的现象是,CBROM的1.03 和1.3版“变色”的结果竟不一样,1.03版的把红色变成浅红,1.3版的却把红色变成灰色(有时变成其他颜色),1.03版的“变色”不是很严重,而1.3版的简直就是张冠李戴地变,效果非常差。由此也可以判断图片是经过CBROM这个程序处理后再压缩进BIOS文件的,而CBROM这个程序也会影响变色。
  上面的分析是不是说不可能避免“变色”呢?其实只要创建图片的过程符合一定的规范,那么基本上可以保证图片不“变色”,下面是笔者在操作中的一点作图经验:

  1. 如果你对PHOTOSHOP(下称“PS”)不是很精通,建议使用WINDOWS自带的画笔程序作图,其因有二:一是用画笔程序的“另存为‘16色位图’”就可以创建符合要求的16色索引位图,而PS要用经过“转换成索引模式”,处理颜色表等多种步骤。二是由于PS功能过强,在RGB模式下它会对图片进行特殊的处理,这样反而使图片容易发生“变色”

  2. 作图时,最好使用黑色为背景色,蓝色为文字及图形色,另外可加一些绿色或白色,而少用些其他颜色。例如图1所示的“金潮电脑”(这牌子听过吗)中除了“潮”字用了绿色外,其他均是蓝色,而这幅图就没有“变色”。

  3. 如果使用画笔,那么只要注意好使用颜色,画好画后再用“另存为‘16色位图’”就可以了。而用PS时要先将“RGB模式”转换为“INDEX模式”(由于这一过程还要载人颜色表,所以最简便的方法是先用画笔程序建立好16色索引位图后,再用PS打开),再进行绘图。因为在“RGB”模式下PS会对图片进行“去锯齿边缘处理”(即用相近的颜色填充边缘),而这样反而容易引起“变色”。

  4. 尽量画直线和矩形之类的规则图形,而少画曲线和圆形之类的,否则最终显示时的“锯齿”现象很严重,影响LOGO图片的整体效果。

  5. 最好使用CBROM的1.03版植入图片,因为即使是变色也不会很严重。

  6. 图片创建的其他注意事项,请参看结论中的第2、3、4条。

oemlogo1.gif

  以上经验的成果就是图1所示的“金潮电脑”(谁在流口水),最终显示时没有变色。当然,如果你觉得创建图片太麻烦的话,也可以到我的网站下载已做好的LOGO图片(个个精彩,不会变色,另外还有配套的WIN9X 动画开机LOGO,赶快下载!)

最后的“手术”

  终于到了给BIOS做“手术”的时候了,如果你有修改BIOS的经历,那么现在已很容易了。首先运行AWDFLASH等BIOS更新程序(建议使用主板商所提供的,如ASUS的PFLASH),将BIOS中的数据保存到文件XXX.BIN中(具体操作请参看有关文章,这里不再细说),然后键入CBROM XXX.BIN /LOGO XXX.BMP将做好的LOGO图片植入BIOS文件,最后用AWDFLASH将已植入图片的BIOS文件更新到ROM中。好了,这样就完事了!哦!别急,还有,真诚地向上帝祈祷,开机后看到的是自己精心设计的LOGO,可别是声、光、味效果惧佳的“青烟”效应(你见过吗?很“精彩”的!)。

唠叨完了(我的手快酸死了!),最后还是要罗嗦一句老话:BIOS修改具有一定危险,修改过程中一定要仔细慎重,以免造成损失!本文所提程序、LOGO图片以及更多更详细的资料可到http://zyweb.myrice.com 下载。另外,本文所述不当之处,还请各位多多指正,我的妹儿是netfree@netease.com


修改 BIOS LOGO F&Q
万一BIOS升级出了问题
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }