RK3399 Android7.1 异形屏修改
属性说明:
persist.sys.framebuffer.xoffset //用来调整水平方向偏移
persist.sys.framebuffer.yoffset //用来调整垂直方向偏移
persist.sys.framebuffer.main //用来设置上层应用的渲染布局,这个属性值与裁剪屏尺寸相关,例如可显示区域为 1920x400,那么就设置为 1920x400@60 即可。
sys.hwc.compose_policy=0 //裁剪屏建议关闭HWC,否则在一些场景显示会出现偏差出现抖屏的情况,修改方法可将build.prop文件中的该字段修改为 0,默认值为 6
HWC_DISPLAY_PRIMARY = 0,
HWC_DISPLAY_EXTERNAL = 1, // HDMI, EDP
hardware\rockchip\hwcomposer\hwcomposer.cpp
static int hwc_get_display_configs(struct hwc_composer_device_1 *dev,
int display, uint32_t *configs,
size_t *num_configs) {
if (!num_configs)
return 0;
struct hwc_context_t *ctx = (struct hwc_context_t *)&dev->common;
DrmConnector *connector = ctx->drm.GetConnectorFromType(display);
if (!connector) {
ALOGE("%s:Failed to get connector for display %d line=%d", __FUNCTION__,display,__LINE__);
return -ENODEV;
}
hwc_drm_display_t *hd = &ctx->displays[connector->display()];
if (!hd->active)
return -ENODEV;
int ret = connector->UpdateModes();
if (ret) {
ALOGE("Failed to update display modes %d", ret);
return ret;
}
if (connector->state() != DRM_MODE_CONNECTED && display == HWC_DISPLAY_EXTERNAL) {
ALOGE("connector is not connected with display %d", display);
return -ENODEV;
}
update_display_bestmode(hd, display, connector);
DrmMode mode = connector->best_mode();
connector->set_current_mode(mode);
char framebuffer_size[PROPERTY_VALUE_MAX];
uint32_t width = 0, height = 0 , vrefresh = 0 ;
if (display == HWC_DISPLAY_PRIMARY)
property_get("persist." PROPERTY_TYPE ".framebuffer.main", framebuffer_size, "use_baseparameter");
else if(display == HWC_DISPLAY_EXTERNAL)
property_get("persist." PROPERTY_TYPE ".framebuffer.aux", framebuffer_size, "use_baseparameter");
android7.1_异形屏修改
0.dts中配置1920x1080的分辨率
1.build.prop添加下面属性:
persist.sys.framebuffer.main=1920x600@60
2.hardware/rockchip/hwcomposer合入下面修改:
diff --git a/hwcomposer.cpp b/hwcomposer.cpp
index 0fd2177..3ad13a9 100755
--- a/hwcomposer.cpp
+++ b/hwcomposer.cpp
@@ -3498,8 +3498,10 @@ static int hwc_get_display_configs(struct hwc_composer_device_1 *dev,
char framebuffer_size[PROPERTY_VALUE_MAX];
uint32_t width = 0, height = 0 , vrefresh = 0 ;
+ if (display == HWC_DISPLAY_PRIMARY)
property_get("persist.sys.framebuffer.main", framebuffer_size, "use_baseparameter");
-
+ else if(display == HWC_DISPLAY_EXTERNAL)
+ property_get("persist.sys.framebuffer.aux", framebuffer_size, "use_baseparameter");
/*
* if unset framebuffer_size, get it from baseparameter , by libin
*/
@@ -2298,7 +2301,8 @@ static int hwc_prepare(hwc_composer_device_1_t *dev, size_t num_displays,
hd->rel_yres = mode.v_display();
hd->v_total = mode.v_total();
hd->w_scale = (float)mode.h_display() / hd->framebuffer_width;
- hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+ //hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+ hd->h_scale = 1.0;
int fbSize = hd->framebuffer_width * hd->framebuffer_height;
//get plane size for display
std::vector<PlaneGroup *>& plane_groups = ctx->drm.GetPlaneGroups();
@@ -3638,7 +3647,8 @@ static int hwc_set_active_config(struct hwc_composer_device_1 *dev, int display,
return -ENOENT;
}
hd->w_scale = (float)mode.h_display() / hd->framebuffer_width;
- hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+ //hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+ hd->h_scale = 1.0;
c->set_current_mode(mode);
ctx->drm.UpdateDisplayRoute();

浙公网安备 33010602011771号