Как автоматически обновить ListView в моем приложении? - PullRequest
0 голосов
/ 27 июня 2018

Я создаю мероприятие, которое может загружать некоторые данные с устройства BLE. Теперь я хочу в реальном времени это значение в ListView моей деятельности. Но я не могу этого сделать. Это мой код:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_ble);

        listView = (ListView) findViewById(R.id.list_view);
        listView.setOnScrollListener(new OnListListener());
        adapter = new SensorDataAdapter(classe, R.layout.sensordata_row, new LinkedList<SensorData>());
        listView.setAdapter(adapter);
        refreshListViewByPosition(null);
        adapter.notifyDataSetChanged();
}

public void refreshListViewByPosition(Integer pos) {
        String tipoCaratteristica=null;
        if(pos!=null && pos ==0)
            tipoCaratteristica = CHARACTERISTIC_FORZA_STRING;
        else if(pos!=null && pos ==1)
            tipoCaratteristica = CHARACTERISTIC_TEMPERATURA_STRING;
        listaDati = db.fetchSensorData(tipoCaratteristica);
        if(listaDati== null || listaDati.size() == 0){
            listaDati = new LinkedList<SensorData>();
            SensorData s = new SensorData("NESSUN ELEMENTO MEMORIZZATO");
            listaDati.add(s);
        }
        adapter.getLista().clear();
        adapter.getLista().addAll(listaDati);
        // fire the event
        adapter.notifyDataSetChanged();
    }

Теперь, когда я получаю значение признака, у меня есть код thid:

@Override
        public void onCharacteristicChanged(BluetoothGatt gatt, BluetoothGattCharacteristic characteristic) {
            //RECUPERO IL CORPO DEL MESSAGGIO
            try{
                ByteBuffer buffer = ByteBuffer.wrap(characteristic.getValue()).order(ByteOrder.LITTLE_ENDIAN);

                byte[] value=buffer.array();

                int valore1 = new Integer(value[3]) * 256 + new Integer(value[2]);
                int valore2 = new Integer(value[5]) * 256 + new Integer(value[4]);
                int valore3 = new Integer(value[7]) * 256 + new Integer(value[6]);
                int valore4 = new Integer(value[9]) * 256 + new Integer(value[8]);
                int valore5 = new Integer(value[11]) * 256 + new Integer(value[10]);
                int valore6 = new Integer(value[13]) * 256 + new Integer(value[12]);
                int valore7 = new Integer(value[15]) * 256 + new Integer(value[14]);
                int valore8 = new Integer(value[17]) * 256 + new Integer(value[16]);

        SensorData mSenData = new SensorData(contatore,valore1+"",valore2+"",valore3+"",
                        valore4+"",valore5+"",valore6+"",valore7+"",valore8+"",
                        Constants.CHARACTERISTIC_FORZA_STRING,
                        db.getDateTime(true));
                mSenData.setValueTimestamp(db.getDateTime(true));

                refreshListView(mSenData);

                db.insertSensorData(mSenData);
            }catch(Exception e){
                Log.e(TAG, e.getMessage());
            }

        }

В этом методе у меня есть метод refreshListView, я передаю ему новый объект SensorData. Это метод:

public void refreshListView(SensorData newRelevation) {
        adapter.getLista().add(0,newRelevation);
        adapter.notifyDataSetChanged();
    }

Но если я попытаюсь запустить этот код, у меня не будет ошибок, но просмотр списка не обновится автоматически.

Учтите, что я получаю новое значение каждые 5 - 10 миллисекунд.

1 Ответ

0 голосов
/ 27 июня 2018

Я рекомендую использовать ScheduledExecutorService, поскольку он очень точный и выгружает пользовательский интерфейс в поток. Вот пример:

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import static java.util.concurrent.TimeUnit.MILLISECONDS;

private final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool( 1 );

Затем вызовите эту функцию:

 private final int INTERVAL = 1000; // milli-seconds

private void scheduleAtFixedRate() {
    final Runnable r = new Runnable() {
        public void run() {
            adapter.notifyDataSetChanged();
        }
    };
    scheduler.scheduleAtFixedRate(r, 0, INTERVAL , MILLISECONDS);
}

В onDestroy звоните:

scheduler.shutdown();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...