android 带权重的圆形按钮数字键盘 [英] android rounded button number pad with weights

查看:30
本文介绍了android 带权重的圆形按钮数字键盘的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用圆形制作动态数字键盘视图,但问题是当我分配背景时它无法正确显示我正在使用权重所以它适用于所有屏幕尺寸和方向我如何实现这是我的布局

i am trying to make dynamic number pad view with rounded shape but the problem is this when i assign background it not showing properly i am using weights so it works on all screen sizes and orientation how can i achieve this is my layout

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

    <LinearLayout android:id="@+id/pin_code_first_row"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:weightSum="3" >

        <Button
            android:id="@+id/pin_code_button_1"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:background="@drawable/rounded"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_2"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_3"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

    </LinearLayout>

    <LinearLayout android:id="@+id/pin_code_second_row"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_below="@+id/pin_code_first_row"
        android:weightSum="3">

        <Button
            android:id="@+id/pin_code_button_4"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_5"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_6"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

    </LinearLayout>

    <LinearLayout android:id="@+id/pin_code_third_row"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_below="@+id/pin_code_second_row"
        android:weightSum="3">

        <Button
            android:id="@+id/pin_code_button_7"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_8"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_9"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

    </LinearLayout>

    <LinearLayout android:id="@+id/pin_code_fourth_row"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_below="@+id/pin_code_third_row"
        android:weightSum="3">

        <Button
            android:id="@+id/pin_code_button_10"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_0"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

        <Button
            android:id="@+id/pin_code_button_clear"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="1" />

    </LinearLayout>

</LinearLayout>

这是我的圆形

    <?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">

    <!-- fill color -->
    <solid android:color="@color/colorAccent" />

    <!-- radius -->
    <stroke
        android:width="1dp"
        android:color="@color/colorAccent" />

    <!-- corners -->
    <corners
        android:radius="2dp"/>
</shape>

但我想让我的布局看起来像这样

but i want to make my layout look like this

如何在不使用静态间距和带有权重的大小的情况下制作此布局,请帮助我我做错了什么?

how can i make this layout without using static spacing and sizes with weights please help me what i am doing wrong?

推荐答案

使用ConstraintLayout如下:

Use ConstraintLayout as below:

这是您的代码:your_layout.xml

<?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="match_parent"
    android:layout_height="match_parent"
    android:background="#75A5CB"
    android:padding="40dp">

    <TextView
        android:id="@+id/tvEnterCode"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp"
        android:gravity="center"
        android:text="Enter Access Code"
        android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvCode"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="4dp"
        android:background="#ffffff"
        android:gravity="center"
        android:minWidth="100dp"
        android:padding="4dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvEnterCode"
        tools:text="..." />

    <Button
        android:id="@+id/pin_code_button_1"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_marginTop="30dp"
        android:background="@drawable/shape_circle_blue"
        android:text="1"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_2"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvCode" />

    <Button
        android:id="@+id/pin_code_button_2"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="2"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_1"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_3"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_1"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_3"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="3"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_1"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_2"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_4"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_marginTop="@dimen/_16sdp"
        android:background="@drawable/shape_circle_blue"
        android:text="4"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_5"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_5"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="5"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_4"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_6"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_1"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_6"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="6"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_4"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_5"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_7"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_marginTop="@dimen/_16sdp"
        android:background="@drawable/shape_circle_blue"
        android:text="7"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_8"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_8"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="8"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_7"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_9"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_4"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_7" />

    <Button
        android:id="@+id/pin_code_button_9"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="9"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_7"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_8"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_7" />

    <Button
        android:id="@+id/pin_code_button_0"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_marginTop="@dimen/_16sdp"
        android:background="@drawable/shape_circle_blue"
        android:text="0"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toEndOf="@+id/pin_code_button_8"
        app:layout_constraintStart_toStartOf="@+id/pin_code_button_8"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_8" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp"
        android:text="Delete"
        android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_0" />
</android.support.constraint.ConstraintLayout>

形状可绘制:your_drawable.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <solid android:color="#4588C0" />
    <stroke
        android:width="2dp"
        android:color="#ffffff" />
</shape>

如果你想用白色显示按下/选择的按钮,那么你必须创建可绘制的选择器并将其放在按钮的背景中.

If you want to display pressed/selected button with white color then you have to create selector drawable and give it in background of button.

如果您不想提供静态垂直边距,请使用以下代码

<?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="match_parent"
    android:layout_height="match_parent"
    android:background="#75A5CB"
    android:padding="40dp">

    <TextView
        android:id="@+id/tvEnterCode"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp"
        android:gravity="center"
        android:text="Enter Access Code"
        android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/tvCode"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="4dp"
        android:background="#ffffff"
        android:gravity="center"
        android:minWidth="100dp"
        android:padding="4dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvEnterCode"
        tools:text="..." />

    <Button
        android:id="@+id/pin_code_button_1"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_marginTop="30dp"
        android:background="@drawable/shape_circle_blue"
        android:text="1"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_2"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tvCode" />

    <Button
        android:id="@+id/pin_code_button_2"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="2"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_1"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_3"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_1"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_3"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="3"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_1"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_2"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_4"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="4"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toTopOf="@+id/pin_code_button_7"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_5"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_1" />

    <Button
        android:id="@+id/pin_code_button_5"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="5"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_4"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_6"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_1"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_6"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="6"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_4"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_5"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_7"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="7"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toTopOf="@+id/pin_code_button_0"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_8"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_4" />

    <Button
        android:id="@+id/pin_code_button_8"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="8"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_7"
        app:layout_constraintEnd_toStartOf="@+id/pin_code_button_9"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_4"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_7" />

    <Button
        android:id="@+id/pin_code_button_9"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="9"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="@+id/pin_code_button_7"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintHorizontal_chainStyle="spread"
        app:layout_constraintHorizontal_weight="1"
        app:layout_constraintStart_toEndOf="@+id/pin_code_button_8"
        app:layout_constraintTop_toTopOf="@+id/pin_code_button_7" />

    <Button
        android:id="@+id/pin_code_button_0"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:background="@drawable/shape_circle_blue"
        android:text="0"
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toTopOf="@+id/tvDelete"
        app:layout_constraintEnd_toEndOf="@+id/pin_code_button_8"
        app:layout_constraintStart_toStartOf="@+id/pin_code_button_8"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_8" />

    <TextView
        android:id="@+id/tvDelete"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp"
        android:text="Delete"
        android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
        android:textColor="#ffffff"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/pin_code_button_0" />
</android.support.constraint.ConstraintLayout>

这篇关于android 带权重的圆形按钮数字键盘的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆