Android屏幕适配AndroidAutoSize的使用「建议收藏」

Android屏幕适配AndroidAutoSize的使用「建议收藏」Android屏幕适配AndroidAutoSize的使用AndroidAutoSize的使用加入依赖配置AndroidManifest.xml主单位或者副单位主单位的配置副单位的配置主单位的使用副单位的使用插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML图表FLowchart流程图导出与导入导出导入AndroidAutoSize的使

大家好,又见面了,我是你们的朋友全栈君。

AndroidAutoSize的使用

记录一下Android屏幕适配框架的使用

加入依赖

implementation ‘me.jessyan:autosize:1.2.1’

配置AndroidManifest.xml主单位或者副单位

主单位的配置

<application>
.......
<meta-data
            android:name="design_width_in_dp"
            android:value="360"/>
        <meta-data
            android:name="design_height_in_dp"
            android:value="640"/>
......            
</application>

副单位的配置

<application>
.......
	<meta-data
   	    android:name="design_width_in_dp"
   	    android:value="1080"/>
	<meta-data
   	    android:name="design_height_in_dp"
   	    android:value="1920"/>
......            
</application>

初始化

在Application中配置AndroidAutoSize

AutoSize.initCompatMultiProcess(this)
/** * 以下是 AndroidAutoSize 可以自定义的参数, [AutoSizeConfig] 的每个方法的注释都写的很详细 * 使用前请一定记得跳进源码,查看方法的注释, 下面的注释只是简单描述!!! */
AutoSizeConfig.getInstance().apply { 
   
    isCustomFragment = true
    onAdaptListener = object : onAdaptListener { 
   
        override fun onAdaptBefore(target: Any, activity: Activity) { 
   
            //使用以下代码, 可以解决横竖屏切换时的屏幕适配问题
            //使用以下代码, 可支持 Android 的分屏或缩放模式, 但前提是在分屏或缩放模式下当用户改变您 App 的窗口大小时
            //系统会重绘当前的页面, 经测试在某些机型, 某些情况下系统不会主动重绘当前页面, 所以这时您需要自行重绘当前页面
            //ScreenUtils.getScreenSize(activity) 的参数一定要不要传 Application!!!
            // AutoSizeConfig.getInstance().setScreenWidth(ScreenUtils.getScreenSize(ac
            // AutoSizeConfig.getInstance().setScreenHeight(ScreenUtils.getScreenSize(a
            String.format(Locale.ENGLISH, "%s onAdaptBefore!", target.javaClass.name)
                .loge("AutoSizeLog")
        }
        override fun onAdaptAfter(target: Any, activity: Activity) { 
   
            String.format(Locale.ENGLISH, "%s onAdaptAfter!", target.javaClass.name)
                .loge("AutoSizeLog")
        }
    }
    //是否使用设备的实际尺寸做适配, 默认为 false, 如果设置为 false, 在以屏幕高度为基准进行适配时
    //AutoSize 会将屏幕总高度减去状态栏高度来做适配
    //设置为 true 则使用设备的实际屏幕高度, 不会减去状态栏高度
    //在全面屏或刘海屏幕设备中, 获取到的屏幕高度可能不包含状态栏高度, 所以在全面屏设备中不需要减去状态栏高度,所以可以 setUseDeviceSize(true)
    isUseDeviceSize = false
    //是否打印 AutoSize 的内部日志, 默认为 true, 如果您不想 AutoSize 打印日志, 则请设置为 false
    setLog(true)
    //是否全局按照宽度进行等比例适配, 默认为 true, 如果设置为 false, AutoSize 会全局按照高度进行适配
    isBaseOnWidth = true
    //设置屏幕适配逻辑策略类, 一般不用设置, 使用框架默认的就好
    //setAutoAdaptStrategy { target, activity ->
    //}
}

主单位的使用

AndroidAutoSize默认适配方案是按照宽来适配的
看下activity_layout的布局
顶部三个TextView宽度分别100dp+160dp+100dp=360dp
纵向一共分为了四个区域100dp+100dp+220dp+220dp=640dp

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical">

    <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal">

        <TextView android:layout_width="100dp" android:layout_height="100dp" android:background="@color/colorAccent" android:gravity="center" android:text="W100DP" android:textColor="#fff" android:textSize="20sp" />
        <TextView android:layout_width="160dp" android:layout_height="100dp" android:background="@color/black" android:gravity="center" android:text="W160DP" android:textColor="@color/white" android:textSize="20sp" />
        <TextView android:layout_width="100dp" android:layout_height="100dp" android:background="#0d0" android:gravity="center" android:text="W100DP" android:textColor="#fff" android:textSize="20sp" />
    </LinearLayout>

    <Button android:layout_width="360dp" android:layout_height="100dp" android:background="#fd0" android:onClick="goCustomAdaptActivity" android:text="Cum" android:textColor="#0d0" android:textSize="70sp" />
    <ImageView android:layout_width="match_parent" android:layout_height="220dp" android:background="@color/colorPrimary" />
    <ImageView android:layout_width="match_parent" android:layout_height="220dp" android:background="@color/colorAccent" />
</LinearLayout>

在1080*2160 DPI400显示效果1080*2160 DPI400
在Pixel_XL 1440*2560 560DPI显示效果
在这里插入图片描述
可以看到两个宽度的显示效果是一样的
下面我们看下以高度为适配基准 AndroidAutoSize默认是以宽度为基准适配的 你可以选择初始化配置的时候全局配置宽度或者高度适配

AutoSizeConfig.getInstance().apply {
				.......
                //是否全局按照宽度进行等比例适配, 默认为 true, 如果设置为 false, AutoSize 会全局按照高度进行适配
                isBaseOnWidth = false
				.......
            }

如果你想让某一个Activity以高度适配为基准可以实现CustomAdapt接口

class LoginActivity : AppCompatActivity(), CustomAdapt { 
   
    override fun onCreate(savedInstanceState: Bundle?) { 
   
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_login)
    }

    override fun isBaseOnWidth()=false

    override fun getSizeInDp()=0f
}

我们来看下以高度为基准的显示效果
在1080*2160 DPI400显示效果
在这里插入图片描述
在Pixel_XL 1440*2560 560DPI显示效果

在这里插入图片描述
可以看到底部的两块区域刚好填充完屏幕

副单位的使用

初始化

//AndroidAutoSize 默认开启对 dp 的支持, 调用 UnitsManager.setSupportDP(false); 可以关闭对 dp 的支持
//主单位 dp 和 副单位可以同时开启的原因是, 对于旧项目中已经使用了 dp 进行布局的页面的兼容
//让开发者的旧项目可以渐进式的从 dp 切换到副单位, 即新页面用副单位进行布局, 然后抽时间逐渐的将旧页面的布局单位从 dp 改为副单位
//最后将 dp 全部改为副单位后, 再使用 UnitsManager.setSupportDP(false); 将 dp 的支持关闭, 彻底隔离修改 density 所造成的不良影响
//如果项目完全使用副单位, 则可以直接以像素为单位填写 AndroidManifest 中需要填写的设计图尺寸, 不需再把像素转化为 dp
//AndroidAutoSize 默认开启对 dp 的支持, 调用 UnitsManager.setSupportDP(false); 可以关闭对 dp 的支持
//主单位 dp 和 副单位可以同时开启的原因是, 对于旧项目中已经使用了 dp 进行布局的页面的兼容
//让开发者的旧项目可以渐进式的从 dp 切换到副单位, 即新页面用副单位进行布局, 然后抽时间逐渐的将旧页面的布局单位从 dp 改为副单位
//最后将 dp 全部改为副单位后, 再使用 UnitsManager.setSupportDP(false); 将 dp 的支持关闭, 彻底隔离修改 density 所造成的不良影响
//如果项目完全使用副单位, 则可以直接以像素为单位填写 AndroidManifest 中需要填写的设计图尺寸, 不需再把像素转化为 dp
AutoSizeConfig.getInstance().unitsManager.apply {
    isSupportDP = true
    supportSubunits = Subunits.MM
}

然后在布局文件中使用mm pt in单位即可 宽高适配基准和主单位一致

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/141009.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号