Android: 水平滑动线性布局的实现

本文介绍如何在Android中创建一个水平滑动的线性布局,用于日期选择。通过自定义一个继承自LinearLayout的视图,并利用ScrollView实现滑动效果。在onMeasure方法中,设置内部LinearLayout的宽度为父布局宽度的两倍,内含多个等宽的子布局,代表不同的日期选项。
摘要由CSDN通过智能技术生成

一:目的:

实现两倍测量宽度的控件,来选择日期

二:原理:

继承一个LinerLayout,使用ScrollView实现滑动,ScrollView包含LinerLayout,此LinerLayout宽度为两倍父LinerLayout的测量宽度

三:实现:

如下代码,在函数onMeasure中,实现了对当前控件及子控件ScrollView的测量,

然后对ScrollView的子控件LinearLayout宽度进行赋值,使其为两倍的父控件宽度。

在布局文件中,子控件LinearLayout包含了很多个等宽的LinearLayout,每个表示一个时间。

<?xml version="1.0" encoding="utf-8"?>
<HorizontalScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/container"
    android:layout_width="match_parent"
    android:layout_height="73dp"
    android:scrollbars="none"
    >

<LinearLayout

    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingTop="10dp"
    android:paddingBottom="4.5dp"
    android:background="@android:color/white"
    android:orientation="horizontal">

    <LinearLayout
        android:id="@+id/day1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:gravity="center"
        android:orientation="vertical">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/txt_22px"
            android:textColor="@color/color_a5"
            android:paddingBottom="4dp"
            android:paddingTop="0dp" />

        <TextView
            android:gravity="center"
            android:layout_width="32.5dp"
            android:layout_height="32.5dp"
            android:background="@drawable/date_time_bg"
            android:textColor="@drawable/color_wb"
            android:textSize="@dimen/txt_32px" />

    </LinearLayout>

    <LinearLayout
        android:id="@+id/day2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:gravity="center"
        android:orientation="vertical">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/txt_22px"
            android:textColor="@color/color_a5"
            android:paddingBottom="4dp"
            android:paddingTop="0dp" />

        <TextView
            android:gravity="center"
            android:layout_width="32.5dp"
            android:layout_height="32.5dp"
            android:background="@drawable/date_time_bg"
            android:textColor="@drawable/color_wb"
            android:textSize="@dimen/txt_32px" />

    </LinearLayout>

    <LinearLayout
        android:id="@+id/day3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:gravity="center"
        android:orientation="vertical">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/txt_22px"
            android:textColor="@color/color_a5"
            android:paddingBottom="4dp"
            android:paddingTop="0dp" />

        <TextView
            android:gravity="center"
            android:layout_width="32.5dp"
            android:layout_height="32.5dp"
            android:background="@drawable/date_time_bg"
            android:textColor="@drawable/color_wb"
            android:textSize&#
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值