在androidstudio中有没有一种在列表视图中显示连续数据的方法?

chhqkbe1  于 2021-06-30  发布在  Java
关注(0)|答案(1)|浏览(306)

我目前正在做一个项目,要求我不断显示数据从蓝牙设备,在这种情况下,重量测量从四个不同的传感器。
我曾尝试使用自定义适配器创建列表视图,但它只会显示一次输入集。列表视图上显示的数据只有在我退出并重新输入片段时才会更新。
我一直试图找到一种方法,在列表视图中不断添加一组新的输入,同时将以前的数据保留在顶部,但我似乎找不到一个很好的参考。
以下是我的列表视图的示例:
我的代码:
我的自定义适配器

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;

import java.util.List;

import static com.shoeinsoleweight.bluetooth_java_fragment.main_activity.InputValue1;
import static com.shoeinsoleweight.bluetooth_java_fragment.main_activity.InputValue2;
import static com.shoeinsoleweight.bluetooth_java_fragment.main_activity.InputValue3;
import static com.shoeinsoleweight.bluetooth_java_fragment.main_activity.InputValue4;

public class Adapter_inputs extends ArrayAdapter<Model_inputs> {

    private final int resourceLayout;

    public Adapter_inputs(Context context, int resourceLayout, List<Model_inputs> inputsList) {
        super(context, resourceLayout, inputsList);

        this.resourceLayout = resourceLayout;

    }

    public View getView(int position, View convertView, ViewGroup parent){
        View v = convertView;

        if(v == null){
            LayoutInflater layoutInflater = LayoutInflater.from(getContext());
            v = layoutInflater.inflate(resourceLayout, null);

        }

        Model_inputs inputs = getItem(position);

        if(inputs != null){
            TextView input1TV = (TextView) v.findViewById(R.id.InputValue1);
            TextView input2TV = (TextView) v.findViewById(R.id.InputValue2);
            TextView input3TV = (TextView) v.findViewById(R.id.InputValue3);
            TextView input4TV = (TextView) v.findViewById(R.id.InputValue4);

            if(input1TV != null){
                input1TV.setText("Input Value 1:" + InputValue1);
            }
            if(input2TV != null){
                input2TV.setText("Input Value 2:" + InputValue2);
            }
            if(input3TV != null){
                input3TV.setText("Input Value 3:" + InputValue3);
            }
            if(input4TV != null){
                input4TV.setText("Input Value 4:" + InputValue4);
            }

        }
        return v;
    }
}

我的模型

package com.shoeinsoleweight.bluetooth_java_fragment;

public class Model_inputs{

    String Input1;
    String Input2;
    String Input3;
    String Input4;

    public Model_inputs(String Input1, String Input2, String Input3, String Input4){
        this.Input1 = Input1;
        this.Input2 = Input2;
        this.Input3 = Input3;
        this.Input4 = Input4;
    }

    public String getInput1() {
        return Input1;
    }

    public String getInput2() {
        return Input2;
    }

    public String getInput3() {
        return Input3;
    }

    public String getInput4() {
        return Input4;
    }

}

我的碎片

public class history_fragment extends Fragment {

    private View decorView;

    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {

        return inflater.inflate(R.layout.history_fragment, container, false);
    }

    public void onViewCreated(View view, Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        List<Model_inputs> inputsList = new ArrayList<>();
        Model_inputs inputs = new Model_inputs("a", "b", "c", "d");
        inputsList.add(inputs);
        ListView listView = (ListView) view.findViewById(R.id.InputValue_LV);
        Adapter_inputs adapter_inputs = new Adapter_inputs(requireActivity(), R.layout.row_inputs, inputsList);
        listView.setAdapter(adapter_inputs);

    }
}

每组数据的xml文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="16dp"
    >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#BFFFFFFF"
        android:backgroundTint="#2B2B2B"
        android:orientation="vertical">

        <TextView
            android:id="@+id/InputValue1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="Input Value 1:"
            android:textColor="#FFF"
            android:textSize="15sp"
            android:textStyle="bold" />

        <TextView
            android:id="@+id/InputValue2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="Input Value 2:"
            android:textColor="#FFF"
            android:textSize="15sp"
            android:textStyle="bold" />

        <TextView
            android:id="@+id/InputValue3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="Input Value 3:"
            android:textColor="#FFF"
            android:textSize="15sp"
            android:textStyle="bold" />

        <TextView
            android:id="@+id/InputValue4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="Input Value 4:"
            android:textColor="#FFF"
            android:textSize="15sp"
            android:textStyle="bold" />

    </LinearLayout>

</LinearLayout>

片段的xml文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:orientation="vertical"
    android:background="@drawable/nightsky"
    tools:context=".history_fragment">

    <FrameLayout
        android:id="@+id/fl_navBar"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/bottom_nav">

        <TextView
            android:id="@+id/History_Text"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="30dp"
            android:background="@null"
            android:ems="10"
            android:fontFamily="casual"
            android:text="@string/history"
            android:textAlignment="center"
            android:textColor="#FFFFFF"
            android:textSize="24sp"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

        <ListView
            android:id="@+id/InputValue_LV"
            android:layout_width="match_parent"
            android:layout_height="585dp"
            android:layout_marginTop="80dp"
            android:background="#BFFFFFFF"
            android:backgroundTint="#2B2B2B" />

    </FrameLayout>

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android:id="@+id/bottom_nav"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:background="#00019184"
        app:itemIconTint="#FFFFFF"
        app:itemTextColor="#FFFFFF"
        app:menu="@menu/nav_menu" />

</RelativeLayout>
hc2pp10m

hc2pp10m1#

而不是在适配器中使用列表用户arraylist。然后,当蓝牙发送数据时(这将是一个侦听器,它将捕获蓝牙数据,可能是一个服务或类似的东西),将数据集添加到要传递给适配器的数组列表中,并在适配器上调用ondatasetchanged()函数,该函数是一个内置方法,用于通知适配器数据集已更改。喜欢

list.add(new Model_inputs("a", "b", "c", "d"));
adapter.notifyDataSetChanged();

这里,“new model\u inputs(“a”、“b”、“c”、“d”)”将是蓝牙设备发送的新数据集。
我建议使用recyclerview而不是listview,它提供了一种更好的方法来扩展视图。i、 它在滚动时回收视图。

相关问题