弹性布局和AndroidAutoSize屏幕适配

弹性布局和AndroidAutoSize屏幕适配导言:技术在不断的革新,需要有新的技术代替老的方案,老的不再维护,新的一直推荐,作为技术也不能一直停滞不前概念:弹性布局(约束布局):ConstraintLayout可以算是RelativeLayout的升级版屏幕适配:百分比和最小宽度从px的AndroidAutoLayout方案到dp,pm等主副单位AndroidAutoSize方案案例步骤:1:ConstraintLayo…

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

导言:
技术在不断的革新,需要有新的技术代替老的方案,老的不再维护,新的一直推荐,作为技术也不能一直停滞不前

概念:
弹性布局(约束布局): ConstraintLayout可以算是RelativeLayout的升级版
屏幕适配: 百分比和最小宽度从px的AndroidAutoLayout方案到dp,pm等主副单位AndroidAutoSize方案

案例步骤:
1:ConstraintLayout(弹性布局(约束布局)):
基本属性:crr,clr,ctb等等,按照400×640设计图dp编写

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="@dimen/dp400"
    android:layout_height="wrap_content"
    tools:context="MainActivity">

    <com.youth.banner.Banner
        android:id="@+id/main_banner"
        android:layout_width="wrap_content"
        android:layout_height="315dp"
        android:layout_alignParentTop="true"
        android:background="#fff"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="30dp"
        android:layout_alignParentTop="true"
        android:alpha="0.2"
        android:background="#FFFFFF"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <ImageView
        android:layout_width="100dp"
        android:layout_height="17dp"
        android:layout_marginLeft="15dp"
        android:layout_marginTop="7dp"
        android:src="@drawable/logo_main"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <ImageView
        android:id="@+id/main_exit_dialog_iv"
        android:layout_width="28dp"
        android:layout_height="18dp"
        android:layout_marginRight="15dp"
        android:layout_marginTop="4dp"
        android:src="@drawable/back_button_main"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/main_notice_iv"
        android:layout_width="18dp"
        android:layout_height="10dp"
        android:layout_marginLeft="@dimen/dp16"
        android:layout_marginTop="@dimen/dp10"
        android:background="@drawable/notice"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/main_banner" />

    <TextView
        android:id="@+id/main_notice_detail"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp10"
        android:layout_marginTop="@dimen/dp5"
        android:text="@string/lottery_notice"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_notice_iv"
        app:layout_constraintTop_toBottomOf="@+id/main_banner" />

    <ImageView
        android:id="@+id/main_image_iv"
        android:layout_width="171dp"
        android:layout_height="256dp"
        android:layout_marginLeft="@dimen/dp16"
        android:layout_marginTop="@dimen/dp5"
        android:src="@drawable/main_image"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/main_notice_iv" />

    <Button
        android:id="@+id/main_p3_bt"
        android:layout_width="55dp"
        android:layout_height="@dimen/dp32"
        android:layout_marginLeft="12dp"
        android:layout_marginTop="@dimen/dp5"
        android:background="@drawable/button_select_p3"
        tools:layout_editor_absoluteX="200dp"
        tools:layout_editor_absoluteY="346dp"
        app:layout_constraintLeft_toRightOf="@+id/main_image_iv"
        app:layout_constraintTop_toBottomOf="@+id/main_notice_detail"/>

    <Button
        android:id="@+id/main_p5_bt"
        android:layout_width="@dimen/dp55"
        android:layout_height="32dp"
        android:layout_marginLeft="12dp"
        android:layout_marginTop="@dimen/dp5"
        android:background="@drawable/button_select_p5"
        app:layout_constraintLeft_toRightOf="@+id/main_p3_bt"
        app:layout_constraintTop_toBottomOf="@id/main_notice_iv" />

    <Button
        android:id="@+id/main_p10_bt"
        android:layout_width="55dp"
        android:layout_height="32dp"
        android:layout_marginLeft="12dp"
        android:layout_marginTop="@dimen/dp5"
        android:background="@drawable/button_select_p10"
        app:layout_constraintLeft_toRightOf="@id/main_p5_bt"
        app:layout_constraintTop_toBottomOf="@id/main_notice_iv" />

    <TextView
        android:id="@+id/main_ten_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp17"
        android:layout_marginTop="@dimen/dp13"
        android:text="bbbbbbbbb"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@id/main_image_iv"
        app:layout_constraintTop_toBottomOf="@id/main_p3_bt" />

    <TextView
        android:id="@+id/main_ticket_num_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp19"
        android:layout_marginRight="@dimen/dp19"
        android:includeFontPadding="false"
        android:text="0"
        android:textColor="@color/result_view"
        android:textSize="80sp"
        android:textStyle="bold"
        app:layout_constraintLeft_toRightOf="@+id/main_image_iv"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/main_ten_tv" />

    <Button
        android:id="@+id/main_sub_bt"
        android:layout_width="@dimen/dp60"
        android:layout_height="@dimen/dp60"
        android:layout_marginLeft="@dimen/dp13"
        android:layout_marginTop="@dimen/dp63"
        android:background="@drawable/button_select_sub"
        app:layout_constraintLeft_toRightOf="@+id/main_image_iv"
        app:layout_constraintTop_toBottomOf="@id/main_ten_tv" />

    <Button
        android:id="@+id/main_add_bt"
        android:layout_width="@dimen/dp60"
        android:layout_height="@dimen/dp60"
        android:layout_marginLeft="@dimen/dp13"
        android:layout_marginRight="@dimen/dp13"
        android:layout_marginTop="@dimen/dp63"
        android:background="@drawable/button_select_add"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/main_ten_tv" />

    <TextView
        android:id="@+id/main_xjf_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp22"
        android:layout_marginTop="5dp"
        android:text="xxx"
        android:textColor="@color/result_view"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_image_iv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <TextView
        android:id="@+id/main_payment_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:text="0"
        android:textColor="@color/color_006"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_xjf_tv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <TextView
        android:id="@+id/main_yuan_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:text="aaa"
        android:textColor="@color/result_view"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_payment_tv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <TextView
        android:id="@+id/main_yuxia_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp15"
        android:layout_marginTop="5dp"
        android:text="yyyyy:"
        android:textColor="@color/result_view"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_yuan_tv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <TextView
        android:id="@+id/main_ticket_surplus_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:text="0"
        android:textColor="@color/color_006"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_yuxia_tv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:text="aaa"
        android:textColor="@color/result_view"
        android:textSize="12sp"
        app:layout_constraintLeft_toRightOf="@+id/main_ticket_surplus_tv"
        app:layout_constraintTop_toBottomOf="@id/main_sub_bt" />

    <Button
        android:id="@+id/main_go_payment_bt"
        android:layout_width="186dp"
        android:layout_height="43dp"
        android:layout_marginLeft="@dimen/dp13"
        android:layout_marginTop="@dimen/dp5"
        android:background="@drawable/go_buy"
        app:layout_constraintLeft_toRightOf="@+id/main_image_iv"
        app:layout_constraintTop_toBottomOf="@id/main_xjf_tv" />

    <TextView
        android:id="@+id/main_device_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/dp15"
        android:layout_marginTop="@dimen/dp10"
        android:text="aaaaa: "
        android:textSize="11sp"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/main_image_iv" />

    <TextView
        android:id="@+id/main_device_serial_num_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="@dimen/dp10"
        android:text="00000000"
        android:textSize="11sp"
        app:layout_constraintLeft_toRightOf="@+id/main_device_tv"
        app:layout_constraintTop_toBottomOf="@+id/main_image_iv" />

</android.support.constraint.ConstraintLayout>

2:AndroidAutoSize
2.1:导包

implementation 'me.jessyan:autosize:1.1.0'

2.2:配置androidmainfest,这个是按照UI给的设计图

 <meta-data
            android:name="design_width_in_dp"
            android:value="400" />
        <meta-data
            android:name="design_height_in_dp"
            android:value="640" />

2.3:其他API
CustomAdapt:修改当前页面的设计图尺寸

public class MainActivity extends AppCompatActivity  implements CustomAdapt  {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.inject(this);
    }
     // @return {@code true} 为按照宽度进行适配, {@code false} 为按照高度进行适配
    @Override
    public boolean isBaseOnWidth() {
        return true;
    }
//根据上面这个赋值,比如原图是宽度400适配,这个改成360宽度
    @Override
    public float getSizeInDp() {
        return 360;
    }
}

CancelAdapt :保存原样,放弃自动适配

ok,结束,以后就用这个.

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 互联网广告综述之点击率特征工程

    互联网广告综述之点击率特征工程

    2021年9月11日
    52
  • pytorch tensor转int_numpy和pytorch

    pytorch tensor转int_numpy和pytorchtensor转换为numpy采用.numpy()函数即可a=torch.tensor([1,2,3])print(a)print(type(a))print(a.dtype)b=a.numpy()print(b)print(type(b))print(b.dtype)输出:torch.tensor整数默认为int64即LongTensor小数默认为float32不过一般对tensor采用tensor.data()或者tensor.detach(

    2022年10月9日
    0
  • C# winform 界面美化技巧(扁平化设计)

    C# winform 界面美化技巧(扁平化设计)C#winform界面美化技巧(扁平化设计)关于C#界面美化的一些小技巧在不使用第三方控件如IrisSkin的前提下,依然可以对winform做出让人眼前一亮的美化首先,我们先来实现主界面的扁平化此处分为两个步骤,第一步是更改winform自带的MainForm窗体属性,第二步是添加窗体事件。将主窗体FormBorderStyle更改为None,这样就得到了一个无边框的窗体(w…

    2022年5月28日
    36
  • ctf-web:文件包含漏洞和举例-HCTF2018 WarmUp「建议收藏」

    ctf-web:文件包含漏洞和举例-HCTF2018 WarmUp「建议收藏」我又回来更新了,这次是关于web方面的文件包含漏洞.我会在后面以详细的角度来写清楚这个漏洞的利用方法.当然,以下都是我自己的理解,表述什么的都有些野人化了.所以希望各位大佬手下留情.一.漏洞产生的原因这个漏洞可以追溯到很久.更准确来说,其实是人为产生的.由于我php学的不是很专业,所以我就拿c语言来举例了.php里面使用的是include命令,c语言使用的是#include预处理命令.作用是相似的.我新建了两个文件,内容如图.wzc.h:#include”stdio.h”voidpri.

    2022年6月4日
    35
  • sql模糊查询like并使用concat拼接

    sql模糊查询like并使用concat拼接模糊查询insure_company,左起0104开头,右边模糊匹配。(like搭配%表示模糊匹配,concat拼接),claim_date同。放入mapper.xml文件中时,只需用#{参数名}代替sql查询中的具体数据即可。

    2022年4月30日
    242
  • 七牛云文件上传_七牛云价格

    七牛云文件上传_七牛云价格七牛云上传图片到七牛云并返回图片URL鸣谢’追逐盛夏流年’:https://blog.csdn.net/j1231230/article/details/80061834在开发项目的时候,经常会用到上传图片的功能,如果把图片全都存放在项目路径下,会导致项目越来越臃肿,因此可以考虑把图片上传交给第三方处理,此处我们采用七牛云进行图片存储。一.七…

    2022年9月22日
    0

发表回复

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

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