Andoid:处理TabLayout中的数据更改

问题描述 投票:0回答:1

我有一个带有TabLayout和ViewPager的布局(文件refuel_order_configuration.xml):

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/refuel_order_configuration"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/layout_corners_only_top"
android:gravity="center_vertical|start"
android:orientation="vertical">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginLeft="20dp"
    android:layout_marginTop="10dp"
    android:layout_marginRight="20dp"
    android:gravity="center_vertical|end"
    android:orientation="horizontal">

    <include layout="@layout/gas_station_info_back" />

    <TextView
        android:id="@+id/refuel_order_column_name"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginBottom="8dp"
        android:layout_marginTop="9dp"
        android:layout_weight="1"
        android:textAlignment="center"
        android:textColor="#545B6E"
        android:textSize="24sp"
        android:textStyle="bold"
        tools:text="FUEL TYPE"
        android:text="FUEL TYPE"/>
</LinearLayout>

<com.google.android.material.tabs.TabLayout
    android:id="@+id/refuelOrderTabLayout"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginStart="16dp"
    app:tabTextColor="#00C2CA"
    app:tabIndicatorColor="#00C2CA"
    android:layout_marginEnd="16dp">

</com.google.android.material.tabs.TabLayout>

<androidx.viewpager.widget.ViewPager
    android:id="@+id/refuelOrderViewPager"
    android:layout_width="wrap_content"
    android:layout_height="330dp"

    />
</LinearLayout>

然后在代码中,我用适配器添加了两个片段。这是片段之一的代码(文件refuel_order_configuration_tab.xml]

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/refuel_order_configuration_tab"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/layout_corners_only_top"
    android:gravity="center_vertical|start"
    android:orientation="vertical">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="16dp"
        android:layout_marginTop="10dp"
        android:layout_marginRight="16dp"
        android:gravity="center_vertical|end"
        android:orientation="horizontal">

        <TextView
            android:id="@+id/tv_order_sum"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:textColor="#212121"
            android:textSize="24sp"
            tools:text="1050 P" />

        <TextView
            android:id="@+id/tv_order_litres"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="end"
            android:textColor="@color/taxi_text"
            android:textSize="24sp"
            tools:text="22.9 л" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="4dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="4dp"
        android:orientation="vertical">

        <androidx.appcompat.widget.AppCompatSeekBar
            android:id="@+id/params_seek_bar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:progress="500"
            android:max="5000"
            android:progressBackgroundTint="#000000"
            android:progressTint="#00C2CA"
            android:thumbTint="#00C2CA" />

        <HorizontalScrollView
            android:id="@+id/order_info_view"
            android:layout_width="match_parent"
            android:layout_marginStart="12dp"
            android:layout_marginEnd="12dp"
            android:layout_height="70dp"
            android:layout_marginTop="16dp"
            android:scrollbars="none">

            <LinearLayout
                android:id="@+id/sum_params_container"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:orientation="horizontal" />

<!--                        <include layout="@layout/gas_column_number"/>-->

        </HorizontalScrollView>
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="16dp"
        android:layout_marginEnd="16dp"
        android:baselineAligned="false"
        android:orientation="horizontal">

        <LinearLayout
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:orientation="vertical">

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/payment_account_label_text"
                android:textColor="#666666" />

            <LinearLayout
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginTop="8dp"
                android:gravity="bottom"
                android:orientation="horizontal">

                <ImageButton
                    android:layout_width="20dp"
                    android:layout_height="20dp"
                    android:adjustViewBounds="true"
                    android:background="#00000000"
                    android:scaleType="centerCrop"
                    android:src="@mipmap/ic_wallet" />

                <TextView
                    android:id="@+id/wallet_name"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_marginStart="10dp"
                    android:textColor="#000000"
                    android:textSize="18sp"
                    tools:text="Bill" />
            </LinearLayout>

        </LinearLayout>

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginEnd="10dp"
            android:orientation="vertical">

            <TextView
                android:id="@+id/order_count_litres"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textColor="#666666"
                android:textSize="18sp"
                tools:text="50 " />
        </LinearLayout>

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:orientation="vertical">

            <ImageButton
                android:id="@+id/bill_configuration"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#FFFFFF"
                android:minWidth="20dp"
                android:minHeight="26dp"
                android:src="@mipmap/arrow_right_gray" />
        </LinearLayout>
    </LinearLayout>

    <View
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:layout_marginStart="16dp"
        android:layout_marginTop="12dp"
        android:layout_marginEnd="16dp"
        android:layout_marginBottom="24dp"
        android:background="#E6E6E6" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="16dp"
        android:layout_marginEnd="16dp"
        android:layout_marginBottom="16dp"
        android:orientation="horizontal">

        <Button
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:width="56dp"
            android:background="@drawable/empty_corner_background"
            android:text="@string/finish_button_text"
            android:textColor="#FFFFFF" />
    </LinearLayout>
</LinearLayout>

当AppCompatSeekBar中的数据发生更改时,我会处理它并在当前布局中在TextView中更改数据

我的问题:如何处理第一个选项卡中的数据更改并将其更改传递给第二个选项卡上的TextView?

[在切换标签页并将此状态转移到另一个标签页时,可能存在一种保存标签页状态的机制,但是我不知道

更新:我通过以下方式解决了问题

  1. 在初始化容器片段的kotlin类中(文件refuel_order_configuration.xml),我初始化适配器

    refuelOrderViewPager.adapter = RefuelOrderConfigAdapter(fragmentManager, view.context)
        refuelOrderTabLayout.setupWithViewPager(refuelOrderViewPager)
    
  2. 在适配器类中,我初始化所谓的DataManager并将其传递到tab的每个kotlin类中。

    class RefuelOrderConfigAdapter(fragmentManager: FragmentManager?,
                               val context: Context) : FragmentStatePagerAdapter(fragmentManager) {
    private val titles: List<String> = listOf(SUM_TAB_HEADER, LITRES_TAB_HEADER)
    private val dataManager = DataManager()
    private val items: List<BaseFragment> = listOf(SumOrderConfigurationTab.instance(TabType.SUM, dataManager),
            LitresOrderConfigurationTab.instance(TabType.LITRES, dataManager))
    init {
        dataManager.registerObserver(items)
    }
    //...other adapter methods
    }
    
  3. 有DataManager的代码。它本质上是模式Observer的一部分。

    class DataManager {
    
    private val observers: ArrayList<BaseFragment> = ArrayList()
    
    fun registerObserver(observerList: List<BaseFragment>) {
        observers.addAll(observerList)
    }
    
    fun notifyObservers(data: String, tabType: TabType) {
        observers.forEach { observer -> observer.handleNotify(data, tabType) }
    }
    

    }

  4. 在seekBar更改时,在片段的每个类中,我都会将数据更改通知观察者,而在handleNotify方法中,我将处理数据更改。

    class SumOrderConfigurationTab:BaseFragment(){

    companion object {
        private lateinit var tabType: TabType
        private lateinit var dataManager: DataManager
        fun instance(tabType: TabType, dataManager: DataManager): SumOrderConfigurationTab {
            this.tabType = tabType
            this.dataManager = dataManager
            return SumOrderConfigurationTab()
        }
    }
    

    //初始化器,逻辑等。

    override fun bindListeners(view: View) {
        seekBar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
            override fun onProgressChanged(seekBar: SeekBar?, progress: Int, fromUser: Boolean) {
                leftVariable.text = seekBar?.progress.toString()
                dataManager.notifyObservers(seekBar?.progress.toString(), tabType)
            }
    
            override fun onStartTrackingTouch(seekBar: SeekBar?) {
                leftVariable.text = seekBar?.progress.toString()
                dataManager.notifyObservers(seekBar?.progress.toString(), tabType)
            }
    
            override fun onStopTrackingTouch(seekBar: SeekBar?) {
                leftVariable.text = seekBar?.progress.toString()
                dataManager.notifyObservers(seekBar?.progress.toString(), tabType)
            }
        })
    }
    
    override fun handleNotify(data: String, type: TabType) {
        if (type != tabType) {
            rightVariable.text = data
        }
    }
    

    }

有效。可以正常工作。但是

  1. 我认为这不是正确而优雅的解决方案。
  2. 在此实现中,扩展的空间很小。解决方案不灵活。
android android-tablayout
1个回答
0
投票

我找到了解决方案。

© www.soinside.com 2019 - 2024. All rights reserved.