AndroidAutoSize 使用教程

AndroidAutoSize 使用教程

AndroidAutoSize🔥 A low-cost Android screen adaptation solution (今日头条屏幕适配方案终极版,一个极低成本的 Android 屏幕适配方案).项目地址:https://gitcode.com/gh_mirrors/an/AndroidAutoSize

1. 项目介绍

AndroidAutoSize 是一个轻量级的Android屏幕适配解决方案,基于今日头条的屏幕适配方案封装而成,提供了自动化和自定义扩展的屏幕适配功能。它简化了在不同分辨率设备上保持布局一致性的复杂过程,同时允许开发者灵活地调整适配策略。

2. 项目快速启动

2.1 添加依赖

首先,在你的 build.gradle 文件(app module)中添加依赖:

dependencies {
    implementation 'me.jessyan:autosize:1.1.2'
}

同步Gradle后,就可以开始使用AndroidAutoSize了。

2.2 初始化配置

在应用程序的 onCreate() 方法中初始化AndroidAutoSize,通常你会在 MyApplication 类里面做这件事:

@Override
protected void attachBaseContext(Context base) {
    super.attachBaseContext(base);
    AutoSizeConfig.getInstance().setContext(base)
            .setUseDeviceDefault(false)
            .init();
}

@Override
public void onCreate() {
    super.onCreate();
    AutoSizeConfig config = AutoSizeConfig.getInstance();
    int designWidthInDp = 360; // 设计稿的标准宽度
    int designHeightInDp = 640; // 设计稿的标准高度
    config.setDesignWidthInDp(designWidthInDp).setDesignHeightInDp(designHeightInDp).apply();
}

这里设置了设计稿的标准宽高,以便进行适配。

2.3 应用适配

现在,你可以让你的Activity自动进行适配。只需确保在 setContentView() 之前调用了 super.onCreate():

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState); // 保证在这行之上
    // ...
    setContentView(R.layout.activity_main);
}

3. 应用案例和最佳实践

3.1 自定义适配策略

如果你需要自定义适配策略,可以创建一个实现 CustomAdapt 接口的类:

public class MyCustomAdapt implements CustomAdapt {
    @Override
    public boolean isBaseOnWidth() {
        return true; // 或者false,取决于你希望基于宽度还是高度适配
    }

    @Override
    public float getSizeInDp() {
        return 360f; // 相应的方向上的设计稿 dp 值
    }
}

然后在初始化配置时使用该策略:

AutoSizeConfig.getInstance().setCustomAdapt(new MyCustomAdapt()).apply();

3.2 纵向适配

对于纵向适配,需要自定义Activity并实现 CustomAdapt

public class VerticalAdaptActivity extends AppCompatActivity implements CustomAdapt {
    ...

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        AutoSizeConfig.getInstance().setCustomAdapt(this).apply();
        setContentView(R.layout.activity_vertical_adapt);
    }

    // 实现 CustomAdapt 接口方法
    @Override
    public boolean isBaseOnWidth() {
        return false;
    }

    @Override
    public float getSizeInDp() {
        return 640f;
    }
}

4. 典型生态项目

由于AndroidAutoSize的设计理念和良好的兼容性,已被广泛应用于各种开源项目,例如:

这些项目在不同程度上利用了AndroidAutoSize来进行屏幕适配和提高用户体验。


以上就是AndroidAutoSize的基本使用及一些实践建议,更多详细信息和进阶用法,可以查阅项目的官方文档源码。祝你在使用过程中一切顺利!

AndroidAutoSize🔥 A low-cost Android screen adaptation solution (今日头条屏幕适配方案终极版,一个极低成本的 Android 屏幕适配方案).项目地址:https://gitcode.com/gh_mirrors/an/AndroidAutoSize

  • 19
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1. 添加依赖 在项目的 build.gradle 文件中添加以下依赖: ``` dependencies { implementation 'me.jessyan:autosize:1.2.1' } ``` 2. 配置设计图尺寸 在 Android Studio 的 values 文件夹中创建 dimens.xml 文件,其中定义设计图的尺寸。例如,定义一个 360x640 的设计图: ``` <resources> <dimen name="design_width">360dp</dimen> <dimen name="design_height">640dp</dimen> </resources> ``` 3. 初始化 在 Application 类中初始化 AndroidAutoSize: ``` public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); // 初始化 AndroidAutoSize AutoSizeConfig.getInstance().init(this); } } ``` 4. 配置适配参数 可以在 Application 类中配置 AndroidAutoSize 的适配参数: ``` public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); // 配置 AndroidAutoSize 的适配参数 AutoSizeConfig.getInstance() .setDesignWidth(360) // 设计图宽度 .setDesignHeight(640) // 设计图高度 .setExcludeFontScale(true) // 排除字体缩放影响 .setUseDeviceSize(false) // 使用设备的实际尺寸 .setInitDensity(320) // 初始密度 .setInitScaledDensity(320); // 初始缩放密度 // 初始化 AndroidAutoSize AutoSizeConfig.getInstance().init(this); } } ``` 5. 使用 在布局文件中使用 dp 单位,AndroidAutoSize 会自动根据设计图尺寸适配不同的设备: ``` <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="20dp" // 使用 dp 单位 android:text="Hello, AndroidAutoSize!" /> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秦俐冶Kirby

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值