Android:多分辨率适配

原文地址:

https://blog.csdn.net/a526001650a/article/details/79149743

 

一、图片适配:

mipmap-xhdpi:720P,表示1280x720分辨率,用于存放2x切图
mipmap-xxhdpi:1080P,表示1920x1080分辨率,用于存放3x切图

mipmap-xxxhdpi:2K,表示2560x1440分辨率,用于存放4x切图

 

二、布局适配:

1、layout目录方式:

res/layout目录后跟分辨率,格式:"layout-高x宽",每个layout目录下都写一个布局文件。

竖屏:layout-1280x720,layout-1920x1080,layout-2560x1440

横屏:layout-land-1280x720,layout-land-1920x1080,layout-land-2560x1440

 

2、dimens文件方式:

(1)values目录后跟dp方式:

res/values目录后跟dp,每个values目录下都写一个dimens.xml文件。

 

3种方式:

 

第1种,格式:"values-sw值dp",屏幕宽高的较小值,大于等于"值"时,取此目录下的dimens文件中的dp值,不受横竖屏影响。

计算方式:值 = 分辨率宽高较小值 / 密度值density

例,1920x1080分辨率,density值为3的,values目录命名如下:

竖屏:values-sw360dp

横屏:values-sw360dp-land

 

第2种,格式:"values-w值dp",屏幕宽度,大于等于"值"时,取此目录下的dimens文件中的dp值,横竖屏切换时取值会变。

计算方式:值 = 分辨率宽度 / 密度值density

例,1920x1080分辨率,density值为3的,values目录命名如下:

竖屏:values-w360dp

横屏:values-w640dp-land

使用:

values-w320dp/dimens.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="dp1">0.89dp</dimen>  <!-- 320/360,四舍五入得到0.89 -->
</resources>
 

values-w360dp/dimens.xml文件(此文件中的dp值为基准值,分辨率宽度1080,密度3,会取此目录下的值):

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="dp1">1.00dp</dimen>  <!-- 基准值 -->
</resources>
 

values-w384dp/dimens.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="dp1">1.07dp</dimen>  <!-- 384/360,四舍五入得到1.07 -->
</resources>
 

values-w392dp/dimens.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="dp1">1.09dp</dimen>  <!-- 392/360,四舍五入得到1.09 -->
</resources>
 

values-w411dp/dimens.xml文件(例如:分辨率宽度1080,密度2.625,会取此目录下的值):

 

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <dimen name="dp1">1.14dp</dimen>  <!-- 411/360,四舍五入得到1.14 -->
</resources>

 

 

 

 


 

 

第3种,格式:"values-h值dp",屏幕高度,大于等于"值"时,取此目录下的dimens文件中的dp值,横竖屏切换时取值会变。

计算方式:值 = 分辨率高度 / 密度值density

 

例,1920x1080分辨率,density值为3的,values目录命名如下:

竖屏:values-h640dp

横屏:values-h360dp-land

 

(2)values目录后跟分辨率方式:

res/values目录后跟分辨率,格式:"values-高x宽",每个values目录下都写一个dimens.xml文件。

竖屏:values-1280x720,values-1920x1080,values-2560x1440

横屏:values-land-1280x720,values-land-1920x1080,values-land-2560x1440

 

3.LinearLayout占比方式:

利用LinearLayout的android:weightSum属性和子View的android:layout_weight="1"实现占比布局

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:weightSum="4">
 
    <TextView
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#f98002"
        android:gravity="center"
        android:text="占比4分之1"/>
 
    <TextView
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="2"
        android:background="#fff222"
        android:gravity="center"
        android:text="占比4分之2"/>
 
    <TextView
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#f00ff2"
        android:gravity="center"
        android:text="占比4分之1"/>
</LinearLayout>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值