如何让uboot启动时显示logo

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何让uboot启动时显示logo相关的知识,希望对你有一定的参考价值。

自定义u-boot的开机logo的方法
  我用的u-boot是2009.08版的。想要修改开机logo为自定义的图片,而不是原来的denx.bmp。
方法其实很简单,只需替换u-boot的tools/logos目录中的denx.bmp,再重新编译(可能需要先执行make clean,再make,新的图片
才会起作用),图片大小不要起过你的屏的大小,色彩深度不能大于256色,即8位色深的图片。
不过,如果你不想替换denx.bmp,而要用自已的图片文件,比如,我用的是rat-linux.bmp文件,也可以。把你的文件拷贝
到/tools/logos目录中,再修改/tools目录下的makefile文件,找到以下代码段

ifeq ($(LOGO_BMP),)
LOGO_BMP= logos/denx.bmp
endif
ifeq ($(VENDOR),atmel)
LOGO_BMP= logos/atmel.bmp
endif
ifeq ($(VENDOR),ronetix)
LOGO_BMP= logos/ronetix.bmp
endif
将其中的LOGO_BMP= logos/denx.bmp改为 LOGO_BMP= logos/rat-linux.bmp即可。重新编译,你的图片就可以起作用了。
  U-boot开机logo的制作方法
在有实现LCD显示和LCD命令行终端的U-boot中,在左上角都有显示一个logo,如果是atmel的芯片,就会有atmel的logo,三星的则是denx的logo。
有的网友发邮件说想改成自己公司的Logo,而且如果是自己玩的话,改成自己喜欢的logo也爽阿。所以今天我做好了实验,将简单的修改方法总结如下:

一、图片的放置路径

所有的开机logo都放在了 /tools/logos 之下,你只需要将你的班子作对应的logo替换就好了。

对于S3C2440,你只需要将denx.bmp替换成你想要的logo就好了。

对于ATMEL的芯片,据说会显示ATMEL的logo,所以替换那个logo即可。

但是你所替换的logo必须和原来的大小、格式一模一样,否则会出现u-boot使用过程中宕机重启的后果。

二、图片的大小标准

不同的logo对应不同的大小,这里S3C2440所对应的是160*96分辨率的BMP图片。

三、图片的转换脚本

在制作图片前,请您现确认您的Linux主机上安装了Netpbm 工具包。如果是ubuntu,你可以直接用新立得安装;如果是别的发行版,可以在 Netpbm主页 下载源代码编译。

将你想要的图片裁减成160*96的JPG图片,然后用以下的脚本处理一下就好了:

#!/bin/sh
#install Netpbm first
jpegtopnm $1 | ppmquant 31 | ppmtobmp -bpp 8 > $2

使用方法: (脚本名) ( 待处理的JPG图片名) (输出文件名)
  2.6 的Kernel LOGO真容易改试着改了一下,似乎比2.4容易。2.6的logo数据在/drivers/video/logo里,ppm文件就是logo图像了。每 个ppm对应一个.c文件,内容大概就是图像尺寸、调色板、位图数据等信息。.c文件无需自己建立,在make的时候如果不存在某个ppm文件对应的.c 文件,就会自动从ppm生成一个,然后把它编译成.o文件。所以看看目录下哪些.ppm文件有同名的.o文件,就说明那个logo被编译进了 kernel。标准的224色logo是logo_linux_clut224.ppm,因此修改这个图片就可以实现修改logo了。
在 windows下,可以用PaintShopProX直接打开ppm进行编辑,编辑完毕后用decrease color depth命令降为224色,然后保存,把logo_linux_clut224.c删掉,重新make就可以了。这个是我昨晚随便改的logo :

在 深入一点点。很容易发现,对于一般的vga console,logo是由drivers/video/fbmem.c里的fb_show_logo()函数显示的,这个函数的调用者是 drivers/video/console/fbcon.c(跟2.4差不多,嗯)。这个函数做的事情不多,就是先把非8位色深的位图转换为8位色深, 然后用info->fbops->fb_imageblit(info,& image);把logo显示出来,有一个cpu时显示一个logo,有2个cpu时显示2个,以此类推。

略加修改,就可以实现将logo居中显示,并加入一个“重复显示右边界”,也就是把logo最右边4个点宽的区域作为背景填充到整个logo bar。diff如下:

--- /gs2e/source/linux26-2edev/drivers/video/fbmem.c2006-08-29 14:07:15.000000000 +0800
+++ ./fbmem.c2006-09-27 20:40:08.000000000 +0800
@@ -375,9 +375,9 @@
int fb_show_logo(struct fb_info *info)

u32 *palette = NULL, *saved_pseudo_palette = NULL;
-unsigned char *logo_new = NULL;
-struct fb_image image;
-int x;
+unsigned char *logo_new = NULL, *border = NULL;
+struct fb_image image, imageborder;
+int x, xoffset;

/* Return if the frame buffer is not mapped or suspended */
if (fb_logo.logo == NULL || info->state != FBINFO_STATE_RUNNING)
@@ -421,12 +421,45 @@
image.height = fb_logo.logo->height;
image.dy = 0;

+#ifdef CONFIG_LOGO_REPEAT_RIGHT
+border = kmalloc(4 * fb_logo.logo->height, GFP_KERNEL);
+if (border != NULL)
+ for (x = 0; x < fb_logo.logo->height; x++) /* use x as y */
+*((u32 *)border + x) = /* will repeat 4 pixels of the right side*/
+*(u32 *)(image.data + (x+1)*fb_logo.logo->width - 4);
+
+ imageborder.depth = 8;
+ imageborder.data = border;
+ imageborder.width = 4;
+ imageborder.height = image.height;
+ imageborder.dy = 0;
+ for (x = 0; x < info->var.xres; x+=4)
+imageborder.dx = x;
+info->fbops->fb_imageblit(info, &imageborder);
+
+ kfree(border);
+
+#endif
+#ifndef CONFIG_CENTER_LOGO
+xoffset = 0;
for (x = 0; x < num_online_cpus() * (fb_logo.logo->width + 8) &&
x <= info->var.xres-fb_logo.logo->width; x += (fb_logo.logo->width + 8))
image.dx = x;
info->fbops->fb_imageblit(info, &image);

-
+#else
+xoffset = (info->var.xres - num_online_cpus() * (fb_logo.logo->width + 8))>>1;
+if (xoffset<0)xoffset = 0;
+ for (x = xoffset; x < num_online_cpus() * (fb_logo.logo->width + 8) + xoffset &&
+ x <= info->var.xres-fb_logo.logo->width+xoffset; x += (fb_logo.logo->width + 8))
+ image.dx = x;
+ info->fbops->fb_imageblit(info, &image);
+
+#endif
kfree(palette);
if (saved_pseudo_palette != NULL)
info->pseudo_palette = saved_pseudo_palette;

我在这里定义了两个配置变量,CONFIG_LOGO_REPEAT_RIGHT和CONFIG_CENTER_LOGO,修改/drivers/video/logo/Kconfig,加上:

config CENTER_LOGO
bool "Center logo"
depends on LOGO
default n
config LOGO_REPEAT_RIGHT
bool "Repeat the right border (4 pixels)"
depends on LOGO
default n

这样就可以在make menuconfig之类的界面中设置是否开启这两项功能了。
参考技术A 最近做Uboot移植遇到了一个问题,正常情况下logo应该放在tools/logos里,但是这次移植完发现,启动的时候直接用了uboot根目录下的logo,

如何在后台运行android应用程序时显示通话屏幕

【中文标题】如何在后台运行android应用程序时显示通话屏幕【英文标题】:how to show call screen while android app running on background 【发布时间】:2012-03-09 13:53:29 【问题描述】:

我正在为 android 2.3.3 制作一个 SIP 应用程序。我可以给某人打电话,当有人给我打电话时会显示我的“来电屏幕”。但是当我的应用程序在后台运行并且有人打电话给我时,“通话屏幕”没有启动。那么我怎样才能让它像正常来电一样启动。

已修复:

清单:在应用标签中添加以下代码

  <receiver android:name=".ReceiverTest" android:enabled="true">
             <intent-filter>
                 <action android:name="com.example.INCOMING_CALL" />
             </intent-filter>
  </receiver>

Receiver类:当我接到电话时,它会打开我的来电页面

public class ReceiverTest extends BroadcastReceiver

    @Override
    public void onReceive(Context arg0, Intent arg1)   
        ...
        Intent nextPage= new Intent("com.example.IncomingPage");
        nextPage.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        arg0.startActivity(nextPage);   
            ...     
    


【问题讨论】:

您说的是传入的 SIP 呼叫还是 VOICE 呼叫? 【参考方案1】:

如果您使用的是 Activity,则您的应用不会在后台运行。当一个新的活动被带到堆栈的顶部时,您的应用程序将暂停并放置在后台。要允许您的应用程序接收任何类型的通知,请尝试运行服务或创建广播接收器来获取您想要侦听的意图。这允许您的应用在不在堆栈顶部时进行处理。

更新

所以你已经注册了一个广播接收器......这很好......但是......如果你在你的活动中注册了它并且活动被杀死了,那么你的应用程序的引用和虚拟机也是如此,并且意图不是已收到。尝试使您的广播接收器独立于活动(即让系统使用清单调用它)。然后,即使您的应用程序已死,您的广播接收器也可以接收意图,并启动您需要的内容。

另一种方法是创建一个注册您的接收器的服务 - 一个服务可以在后台运行,但您必须担心让您的服务足够轻而不会被杀死(更多技巧)。最好的是选项 1(开销更少)。

【讨论】:

我认为你不了解我,或者我不了解你。让我解释一下这种方式。我运行我的应用程序,然后注册我的广播接收器以接收来电,它在我的应用程序中运行良好。如果我按下“主页按钮”,我的应用程序会进入后台,但我仍然可以接听电话,现在问题来了,我希望我的应用程序出现在屏幕上,以便我可以拒绝或接听电话。 我明白你在说什么。当您的应用程序在后台运行时,当有人呼叫您时,您的呼叫屏幕不会显示。再次......在后台运行的应用程序出于所有目的都是“死的”,除非有一个广播接收器可以获取来电的意图,或者一个正在检测它的服务。阅读更新以获取更多信息.... 哦,现在我知道你的意思了,谢谢你的理解

以上是关于如何让uboot启动时显示logo的主要内容,如果未能解决你的问题,请参考以下文章

如何让uboot启动时显示logo

如何避免在后台运行时启动应用程序时显示启动画面?

如何在应用启动和退出时显示 Admob 插页式广告

如何在启动时显示 KivyMD 数据表?

如何在应用程序启动时显示锁定屏幕?

在应用启动时显示 ViewController