[触觉智能RK3568]修改屏幕 DPI(像素密度)

系统 OpenHarmony
在源码Foundation/window/window_manager/resources/config/rk3568/display_manager_config.xml中有rk3568的默认配置。

想了解更多关于开源的内容,请访问:

​51CTO 开源基础软件社区​

​https://ost.51cto.com​

  • 触觉智能RK3568购买链接如下:https://item.taobao.com/item.htm?spm=4645b.1.14.1.5c4a4a7dv1soeZ&id=658789039056&ns=1&abbucket=5#detail

一、OpenHarmony源码中DPI配置

  • 在源码foundation/window/window_manager/resources/config/rk3568/display_manager_config.xml中有rk3568的默认配置

rk3568开发板默认的DPI配置为240,范围为80-640。

<!--Window display dpi, valid range is 80~640, use 0 if no configuration is requeired-->
<dpi>240</dpi>

以下为触觉智能开发板在不同DPI时屏幕的显示情况。

DPI为240时:

DPI为100时:

DPI为600时:

二、更改开发板的DPI

方法一:更改源码编译烧录固件

  • 在源码foundation/window/window_manager/resources/config/rk3568/display_manager_config.xml文件中修改dpi,编译后烧录固件。
<!--Window display dpi, valid range is 80~640, use 0 if no configuration is requeired-->
<dpi>240</dpi>

方法二:发送display_manager_config.xml文件至设备etc/window/resources

  • OpenHarmony固件编译烧录进入设备后,display_manager_config.xml文件会被预编译打包至设备端etc/window/resources目录下,什么,为什么只有window/resources字段,因为ohos_prebuilt_etc就是把文件放进设备的etc文件夹。
foundation/window/window_manager/resources/config/BULID.gn文件如下,
下面代码的意思是源码foundation/window/window_manager/resources/config/rk3568/display_manager_config.xml会真正安装在设备中的etc/window/resources文件位置,

ohos_prebuilt_etc("display_manager_config") {
if (device_name == "rk3568") {
source = "//foundation/window/window_manager/resources/config/rk3568/display_manager_config.xml"
install_enable = true
···
···
relative_install_dir = "window/resources"
}
  • 步骤如下
# 进入sdk\版本号\toolchain输入cmd打开命令行,重新加载系统为可读写
D:\DevEco Studio\sdk\9\toolchains>hdc_std shell mount -o remount,rw /

# 替换/etc/window/resources中的display_manager_config.xml文件
D:\DevEco Studio\sdk\9\toolchains>hdc_std file send C:\Users\jjh\display_manager_config.xml /etc/window/resources

然后重启开发板让设置生效

知识点附送

为ohos_prebuilt_XXX类目标添加支持指定output属性的能力

  • 以该pr学习 https://gitee.com/openharmony/build/pulls/822/files 为ohos_prebuilt_XXX类目标添加支持指定output属性的能力。
  • ohos_prebuilt_XXX类目标是指ohos_prebuilt_executable、ohos_prebuilt_shared_library、ohos_prebuilt_static_library、ohos_prebuilt_etc。这类目标只支持指定source属性,拷贝到out目录时目标文件名与源文件名是一样的,无法另行指定名字。该pr解决了此限制,添加了output这个可选属性用于指定目标文件名,不指定的情况下默认与源文件名是一样的(与原逻辑保持一致)。
  • OpenHarmony编译构建子系统是基于Gn和ninja的,而gn本身是有原生模板(source_set,shared_library, static_library, action, executable,group)。gn也支持用户自定义编译模板,OpenHarmony编译子系统提供了一系列自定义的模板(ohos_shared_library、ohos_prebuilt_executable、ohos_prebuilt_shared_library等)
  • 自定义模板的源码位于 https://gitee.com/openharmony/build/tree/master/templates
  • ohos_prebuilt_executable、ohos_prebuilt_shared_library、ohos_prebuilt_static_library、ohos_prebuilt_etc预编译模板在prebuilt.gni中定义,它们通过调用ohos_copy模板实现。
  • ohos_copy模板实现了拷贝文件到设备具体位置的功能,它需要定义invoker.sources和invoker.outputs,即source和output属性。例如
  • ohos_prebuilt_executable、ohos_prebuilt_shared_library、ohos_prebuilt_static_library、ohos_prebuilt_etc(下面用ohos_prebuilt_xxx代指)添加支持指定output属性的能力的相关代码如下:
templates/common/copy.gni文件中:

template("ohos_copy") {
assert(defined(invoker.sources),
"sources must be defined for ${target_name}.")
assert(defined(invoker.outputs),
"outputs must be defined for ${target_name}.")
...
if (_is_prebuilt) {
_outputs = invoker.outputs
module_source = string_replace(_outputs[0], "${target_out_dir}/", "", 1)
}
prebuilt = _is_prebuilt
···
templates/cxx/prebuilt.gni文件中:
template("ohos_prebuilt_xxx") {
···
# 如果.gn文件中为ohos_prebuilt_xxx指定了out属性,文件名称被另外指定。没有则默认为原名称
if (defined(invoker.output)) {
_copy_output = "${target_out_dir}/${invoker.output}"
} else {
_copy_output = "${target_out_dir}/${invoker.source}"
}
···
outputs = [ _copy_output ]
}

使能/禁用selinux

  • 禁用selinux
hdc_std shell mount -o rw,remount /
hdc_std shell "sed -i 's/enforcing/permissive/g' /system/etc/selinux/config"
hdc_std shell "cat /system/etc/selinux/config |grep SELINUX="
# 重启设备
hdc_std shell reboot
  • 使能selinux
hdc_std shell mount -o rw,remount /
hdc_std shell "sed -i 's/permissive/enforcing/g' /system/etc/selinux/config"
hdc_std shell "cat /system/etc/selinux/config |grep SELINUX="
# 重启设备
hdc_std shell reboot

想了解更多关于开源的内容,请访问:

​51CTO 开源基础软件社区​

​https://ost.51cto.com​

责任编辑:jianghua 来源: 51CTO 开源基础软件社区
相关推荐

2023-03-13 15:18:04

NDK工具

2023-03-03 21:36:02

鸿蒙操作系统

2023-02-10 15:34:45

Node.jsN-API组件

2022-04-25 09:10:50

RK3568鸿蒙

2023-03-07 15:54:45

鸿蒙Mesa库

2023-08-18 14:34:09

HDF驱动框架

2023-03-13 11:58:03

拓扑架构模块

2013-03-28 13:27:14

Android获取屏幕

2023-11-24 09:48:29

C++鸿蒙

2023-10-08 15:23:09

侧获取屏幕DPI鸿蒙

2022-05-23 10:45:34

DAYU200鸿蒙

2013-08-13 11:25:56

屏幕尺寸Android应用

2013-03-18 09:58:58

Windows 8

2016-12-14 09:50:28

2023-08-08 14:26:59

开源开发板鸿蒙

2009-04-16 10:16:53

DPIDFI流量

2023-07-11 07:05:15

老人机天语手机屏幕

2014-12-15 10:25:21

移动开发像素设计

2022-05-27 13:37:55

算法触觉

2024-07-26 10:22:22

点赞
收藏

51CTO技术栈公众号