更新ViewPager中所选项目的样式?

时间:2019-12-18 23:30:02

标签: java android xml android-layout android-viewpager

我想更新ViewPager中所选项目的样式。 我该怎么办?

Design 1

这是UI设计。如您所见,“十一月”标签被选中,因此相应的栏以黄色突出显示。

我实现的方式是使用自定义项目(白色,未突出显示)的ViewPager:

<?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="match_parent">

    <androidx.cardview.widget.CardView
        android:layout_width="142dp"
        android:layout_height="275dp"
        android:layout_margin="0dp"
        app:cardElevation="0dp"
        app:cardBackgroundColor="@android:color/transparent">

        <TextView
            android:id="@+id/monthly_spend_month"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/December"
            android:textColor="@color/aluminum"
            android:textSize="20sp"
            android:textStyle="normal"
            android:layout_marginStart="22dp"
            android:layout_marginTop="34dp"/>

        <RelativeLayout
            android:id="@+id/monthly_spend_card"
            android:layout_marginTop="120dp"
            android:layout_marginStart="22dp"
            android:layout_width="120dp"
            android:layout_height="155dp"
            android:background="@drawable/monthlyspend_card_bg_inactive">

            <TextView
                android:id="@+id/monthly_spend_text"
                android:textColor="@color/almost"
                android:layout_marginTop="50dp"
                android:layout_marginStart="22dp"
                android:text="Total
                spent"
                android:textSize="@dimen/balanceDescTextSize"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />

            <TextView
                android:id="@+id/monthly_spend_amount"
                android:textColor="@color/almost"
                android:layout_marginTop="10dp"
                android:layout_marginStart="22dp"
                android:layout_below="@id/monthly_spend_text"
                android:text="$ 254.98"
                android:textSize="@dimen/balanceDescTextSize"
                android:textStyle="bold"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
        </RelativeLayout>

    </androidx.cardview.widget.CardView>

</LinearLayout>

我打算以编程方式进行突出显示。

以下是一些适配器代码:

    @NonNull
    @Override
    public Object instantiateItem(@NonNull ViewGroup container, int position) {
        layoutInflater = LayoutInflater.from(context);
        View view = layoutInflater.inflate(R.layout.monthlyspend_item, container, false);

        TextView monthlySpendMonth, monthlySpendAmount;

        monthlySpendCard = view.findViewById(R.id.monthly_spend_card);
        monthlySpendMonth = view.findViewById(R.id.monthly_spend_month);
        monthlySpendAmount = view.findViewById(R.id.monthly_spend_amount);

        monthlySpendMonth.setText(monthlySpendings.get(position).getMonth());
        monthlySpendAmount.setText(monthlySpendings.get(position).getAmountSpent());

        container.addView(view, 0);

        return view;
    }

任何帮助将不胜感激!

0 个答案:

没有答案