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单位即可 宽高适配基准和主单位一致

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

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

(0)
上一篇 2022年5月26日 下午8:00
下一篇 2022年5月26日 下午8:20


相关推荐

  • memcached 与redis 的区别?

    memcached 与redis 的区别?1 Redis 不仅仅支持简单的 k v 类型的数据 同时还提供 list set zset hash 等数据结构的存储 而 memcache 只支持简单数据类型 需要客户端自己处理复杂对象 2 Redis 支持数据的持久化 可以将内存中的数据保持在磁盘中 重启的时候可以再次加载进行使用 PS 持久化在 rdb aof 3 由于 Memcache 没有持久化机制 因此宕机所有缓存数据失效 Redis 配置为持久化 宕机重启后 将自动加载宕机时刻的数据到缓存系统中 具有更好的灾备机制 4 Memcache 可以

    2026年3月19日
    2
  • js打印页面指定区域内容

    js打印页面指定区域内容js 打印页面指定区域

    2026年3月20日
    3
  • jdbc是数据库连接池么_零之轨迹超详细攻略

    jdbc是数据库连接池么_零之轨迹超详细攻略JDBC数据库连接池一、JDBC数据库连接池的必要性二、数据库连接池技术三、多种开源的数据库连接池3.1C3P0数据库连接池3.2DBCP数据库连接池3.3Druid(德鲁伊)数据库连接池一、JDBC数据库连接池的必要性1、在使用开发基于数据库的web程序时,传统的模式基本是按以下步骤:(1)在主程序(如servlet、beans)中建立数据库连接(2)进行sql操作(3)断开数据库连接2、这种模式开发,存在的问题:(1)普通的JDBC数据库连接使用DriverManager来

    2025年12月13日
    5
  • javascript替换换行符的正确方法

    javascript替换换行符的正确方法js报错(Error:unterminatedstringliteral),原因是字符串中包含换行符,需要用javascript替换换行符,兼容IE和Firefox的正确方法是,使用正则并且把\r和\n分开替换:str.replace(/\r/ig,“”).replace(/\n/ig,“”);需要注意的是:1.javascript的replace只能替换一次…

    2022年5月23日
    48
  • 2021最新Java基础篇(后续已更新到另一篇文章)

    2021最新Java基础篇(后续已更新到另一篇文章)提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、Java基础?1.1什么是变量:1.2类型的分类:1.3类型的大小:1.4类型的转换与强制类型转换:二、使用步骤1.引入库2.读入数据总结前言提示:在这里可以学到Java基础内容。一、Java基础?1.1什么是变量:变量就是系统为程序分配的一块内存单元,用来存储各种类型的数据。由于该存储单元中的数据可以发生改变,因此得名为”变量”1.2类型的分类:1、基本数据类型变量2、引用数据类型变量

    2022年7月9日
    21
  • stm32开发板套件

    stm32开发板套件

    2026年3月15日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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