【问题标题】:How to achieve circular UI in tab view android java如何在标签视图android java中实现循环UI
【发布时间】:2022-01-29 20:24:36
【问题描述】:

我正在为客户开发一个项目,他们给了我 UI,我必须在其中实现某个选项卡,如布局,我想知道如何在 android 上实现这种选项卡。我附上了下面的图片。任何帮助将不胜感激。

我想要实现的目标的快照

【问题讨论】:

    标签: java android kotlin


    【解决方案1】:

    如果您不介意,那么这个答案不是基于标签视图 android java 中的循环 UI,但它几乎可以满足您的需求。

    输出(请不要介意应用名称):

    您可以使用此 XML 代码实现您的需求:

    <?xml version="1.0" encoding="utf-8"?>
    <androidx.constraintlayout.widget.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:layout_gravity="center"
    android:background="#EDFAFF"
    tools:context=".MainActivity">
    
    
    <ImageView
        android:id="@+id/personalInfoTab"
        android:layout_width="30dp"
        android:layout_height="30dp"
        android:layout_marginStart="50dp"
        android:layout_marginTop="30dp"
        android:contentDescription="@string/app_name"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@drawable/radio_btn_checked"
        app:tint="@color/black" />
    
    <ProgressBar
        android:id="@+id/personalInfoProgress"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="120dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="-4dp"
        android:max="100"
        app:layout_constraintBottom_toBottomOf="@+id/personalInfoTab"
        app:layout_constraintStart_toEndOf="@+id/personalInfoTab"
        app:layout_constraintTop_toTopOf="@+id/personalInfoTab" />
    
    <ImageView
        android:id="@+id/paymentTab"
        android:layout_width="30dp"
        android:layout_height="30dp"
        app:layout_constraintBottom_toBottomOf="@+id/personalInfoProgress"
        app:layout_constraintEnd_toStartOf="@+id/paymentProgressBar"
        app:layout_constraintStart_toEndOf="@+id/personalInfoProgress"
        app:layout_constraintTop_toTopOf="@+id/personalInfoProgress"
        app:srcCompat="@drawable/ic_baseline_circle_24"
        app:tint="#353535" />
    
    <ProgressBar
        android:id="@+id/paymentProgressBar"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="120dp"
        android:layout_height="wrap_content"
        app:layout_constraintBottom_toBottomOf="@+id/paymentTab"
        app:layout_constraintEnd_toStartOf="@+id/confirmationTab"
        app:layout_constraintTop_toTopOf="@+id/paymentTab" />
    
    <ImageView
        android:id="@+id/confirmationTab"
        android:layout_width="30dp"
        android:layout_height="30dp"
        android:layout_marginEnd="50dp"
        app:layout_constraintBottom_toBottomOf="@+id/paymentProgressBar"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="@+id/paymentProgressBar"
        app:srcCompat="@drawable/ic_baseline_circle_24"
        app:tint="#353535" />
    
    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Personal Info"
        app:layout_constraintEnd_toStartOf="@+id/personalInfoProgress"
        app:layout_constraintStart_toStartOf="@+id/personalInfoTab"
        app:layout_constraintTop_toBottomOf="@+id/personalInfoTab" />
    
    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Payment"
        app:layout_constraintEnd_toStartOf="@+id/paymentProgressBar"
        app:layout_constraintStart_toEndOf="@+id/personalInfoProgress"
        app:layout_constraintTop_toBottomOf="@+id/paymentTab" />
    
    <TextView
        android:id="@+id/textView3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Confirmation"
        app:layout_constraintEnd_toEndOf="@+id/confirmationTab"
        app:layout_constraintStart_toEndOf="@+id/paymentProgressBar"
        app:layout_constraintTop_toBottomOf="@+id/confirmationTab" />
    
    //frameLayout for your fragments
    <FrameLayout
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="16dp"
        android:layout_marginEnd="16dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/textView2">
    
     </FrameLayout>
     </androidx.constraintlayout.widget.ConstraintLayout>
    

    现在您可以增加进度,您可以将片段用于不同的页面,即:个人信息付款确认

    【讨论】:

    • 谢谢,这是一个非常简洁的解决方案。
    猜你喜欢
    • 2016-03-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-09-30
    • 2020-07-18
    相关资源
    最近更新 更多