正点原子Imx6ULL+LCD屏,竖屏使用时如何修改开机进度条

正点原子给出的修改开机进度条,在使用时LCD是基于横版情况设定的,那对于像手机一样竖屏时,会发现不合适,因此对此进行了研究。
首先准备图片,将logo-alientek.png、logo-psplash-bar.png文件旋转90度,旋转后如图所示。

在这里插入图片描述

接下来,修改psplash.c文件中的源代码。主要修改以下几处:
(1)修改logo-psplash-bar-img.h中的宏定义
因为旋转了,需要把width和height这两个换一下。

在这里插入图片描述
(2)logo-psplash-bar-img.h,同样也要换一下长和宽的数据。
在这里插入图片描述

(3)修改psplash.c这个文件中的代码。
这部分参照CSDN上的一篇博文,原创作者beny610写的“psplash进度条旋转成功”,按这个文章中修改后发现只有进度条,没有先前自己设定的bar这一显示。
另外,所选择的图片在生成开机界面中的poky-logo图片,相对屏幕可能是偏的,poky-logo距离屏幕左右边距不等,但在该博文中没有提及这一情况。

针对这两个问题,在对psplash.c这个文件进行分析后,进行了以下修改:
(1)调整bar border这个函数中的参数
/* Draw progress bar border */
psplash_fb_draw_image (fb,
100,// (fb->width - BAR_IMG_WIDTH)/2,
SPLIT_LINE_POS(fb)-383,//

BAR_IMG_WIDTH,
BAR_IMG_HEIGHT,
BAR_IMG_BYTES_PER_PIXEL,
BAR_IMG_ROWSTRIDE,
BAR_IMG_RLE_PIXEL_DATA);
这里,100是和进度条的位置相对应的,我设定的是100,这个数值相对于屏幕更靠近屏幕的底边,这个值增大时,可以改变bar 这个框与屏幕下边距的距离,即可以调整bar在屏幕上的垂直高度。
SPLIT_LINE_POS(fb)-383,这里是调整屏幕竖起来时左右位置的,我用的10寸屏,用的是383,具体结合自己的屏幕调整383这个数值。
(2)调整Draw Poky logo这个函数中的参数

/* Draw the Poky logo */
psplash_fb_draw_image (fb,
(fb->width - POKY_IMG_WIDTH)/2+100,
#if PSPLASH_IMG_FULLSCREEN
(fb->height - POKY_IMG_HEIGHT)/2,
#else
(fb->height * PSPLASH_IMG_SPLIT_NUMERATOR
/ PSPLASH_IMG_SPLIT_DENOMINATOR -
POKY_IMG_HEIGHT+100)/2,
修改这两处,***其中(fb->width - POKY_IMG_WIDTH)/2+100这一句中的100,***是调整竖屏时图片距离屏幕上边距的位置,具体结合自己的屏幕设定此值。
(fb->height * PSPLASH_IMG_SPLIT_NUMERATOR
/ PSPLASH_IMG_SPLIT_DENOMINATOR - POKY_IMG_HEIGHT+100)/2,

在这一句同样也存在一个调整值100,这个是调整Poky logo图片左右不对称的修正值,这个值根据屏幕具体调整。
(3)调整进度条描绘函数draw_progress中的参数

修改进度条描绘函数,修改后的代码如下,这部分主要参考csdn博文。
psplash_draw_progress (PSplashFB fb, int value)
{
int x, y, width, height, barhight; //barwidth;
/
4 pix border */
x =104; //这里的104是配合bar所在的位置及bar中的边框数值大小
//设定的,具体结合自己的屏幕与bar的图片设定与修改。

y = ((fb->height -BAR_IMG_WIDTH)/2)+4; //SPLIT_LINE_POS(fb) + 4;
width = BAR_IMG_HEIGHT - 8;
height = BAR_IMG_WIDTH - 8;

if (value > 0)
{
barhight = (CLAMP(value,0,100) * height) / 100;
psplash_fb_draw_rect (fb, x , y+ barhight,
width , height- barhight,
PSPLASH_BAR_BACKGROUND_COLOR);
psplash_fb_draw_rect (fb, x, y, width,
barhight, PSPLASH_BAR_COLOR);
}
else
{
barhight = (CLAMP(-value,0,100) * height) / 100;
psplash_fb_draw_rect (fb, x, y,
width, height-barhight,//width - barwidth, height,
PSPLASH_BAR_BACKGROUND_COLOR);
psplash_fb_draw_rect (fb, x ,
y, width, barhight,
PSPLASH_BAR_COLOR);
}

DBG(“value: %i, width: %i, barhight :%i\n”, value,
width, barhight);
}

修改完这3处源代码以后,参照正点原子修改进度条文档进行设置、编译,将生成的psplash和psplash-write这两个文件拷贝到/usr/bin/中,reboot,既可以看到一个没有偏置的Poky-logo,以及在bar中显示的进度条信息。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值