Android:多分辨率适配

一、图片适配:
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文件。


扫描二维码关注公众号,回复: 3306086 查看本文章

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>


猜你喜欢

转载自blog.csdn.net/a526001650a/article/details/79149743