我目前正在做一个项目,要求我不断显示数据从蓝牙设备,在这种情况下,重量测量从四个不同的传感器。
我曾尝试使用自定义适配器创建列表视图,但它只会显示一次输入集。列表视图上显示的数据只有在我退出并重新输入片段时才会更新。
我一直试图找到一种方法,在列表视图中不断添加一组新的输入,同时将以前的数据保留在顶部,但我似乎找不到一个很好的参考。
以下是我的列表视图的示例:
我的代码:
我的自定义适配器
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>
1条答案
按热度按时间hc2pp10m1#
而不是在适配器中使用列表用户arraylist。然后,当蓝牙发送数据时(这将是一个侦听器,它将捕获蓝牙数据,可能是一个服务或类似的东西),将数据集添加到要传递给适配器的数组列表中,并在适配器上调用ondatasetchanged()函数,该函数是一个内置方法,用于通知适配器数据集已更改。喜欢
这里,“new model\u inputs(“a”、“b”、“c”、“d”)”将是蓝牙设备发送的新数据集。
我建议使用recyclerview而不是listview,它提供了一种更好的方法来扩展视图。i、 它在滚动时回收视图。