OpenHarmony开源社区
直播中

ss

7年用户 8762经验值
擅长:电源/新能源 制造/封装 RF/无线
私信 关注
[经验]

求一种屏幕适配UI设计图解决方案

先上图

这个是实现渲染

这个是UI设计图

看看实际效果
平板

移动端

使用方法
RpxUtil.rpx(23,this.context) 直接按照UI尺寸调用即可
源码
package com.example.shangjinlieren.utils;
import ohos.agp.window.service.Display;
import ohos.agp.window.service.DisplayManager;
import ohos.app.Context;
public  class  RpxUtil {
  private  static float WIDTH=750;
  private  static float HEIGHT=1334;
    public static  float rpx(int value, Context context){
       float wRatioValue=  (getDisplayWidthInPx(context)/WIDTH)*value;
        float hRatioValue=  ( getDisplayHeightInPx(context)/HEIGHT)*value;
        float h =0;
        if (value<=750){
            h= wRatioValue;
        }else if (value>750){
            h=hRatioValue;
        }
        return   h;
    }
    /**
     * 获取屏幕宽度
     *
     * @Return 屏幕宽度
     */
    public static int getDisplayWidthInPx( Context context) {
        Display display = DisplayManager.getInstance().getDefaultDisplay(context).get();
        return display.getAttributes().width;
    }
    /**
     * 获取屏幕高度,不包含状态栏的高度
     * @return 屏幕高度,不包含状态栏的高度
     */
    public static int getDisplayHeightInPx( Context context) {
        Display display = DisplayManager.getInstance().getDefaultDisplay(context).get();
        return display.getAttributes().height;
    }
}

更多回帖

发帖
×
20
完善资料,
赚取积分