我有一堆UI正在被一个不断被调用的循环更新。然而它似乎陷入困境;我将如何使用AsyncTask
来加快速度?
以下是UI的循环:
class Looper extends BaseIOIOLooper {
/**
* Called every time a connection with IOIO has been established.
* Typically used to open pins.
*
* @throws ConnectionLostException
* When IOIO connection is lost.
*
* @see ioio.lib.util.AbstractIOIOActivity.IOIOThread#setup()
*/
@Override
protected void setup() throws ConnectionLostException {
led_ = ioio_.openDigitalOutput(0, true);
DO1 = ioio_.openDigitalOutput(6, false);
DO2 = ioio_.openDigitalOutput(7, false);
DO3 = ioio_.openDigitalOutput(8, false);
DO4 = ioio_.openDigitalOutput(9, false);
DO5 = ioio_.openDigitalOutput(10, false);
DO6 = ioio_.openDigitalOutput(11, false);
DO7 = ioio_.openDigitalOutput(12, false);
DO8 = ioio_.openDigitalOutput(13, false);
DO9 = ioio_.openDigitalOutput(14, false);
DO10 = ioio_.openDigitalOutput(15, false);
DO11 = ioio_.openDigitalOutput(16, false);
DO12 = ioio_.openDigitalOutput(17, false);
DI1 = ioio_.openDigitalInput(18);
DI2 = ioio_.openDigitalInput(19);
DI3 = ioio_.openDigitalInput(20);
DI4 = ioio_.openDigitalInput(21);
DI5 = ioio_.openDigitalInput(22);
DI6 = ioio_.openDigitalInput(23);
DI7 = ioio_.openDigitalInput(24);
DI8 = ioio_.openDigitalInput(25);
DI9 = ioio_.openDigitalInput(26);
AI1 = ioio_.openAnalogInput(31);
AI2 = ioio_.openAnalogInput(32);
AI3 = ioio_.openAnalogInput(33);
AI4 = ioio_.openAnalogInput(34);
AI5 = ioio_.openAnalogInput(35);
AI6 = ioio_.openAnalogInput(36);
AI7 = ioio_.openAnalogInput(37);
AI8 = ioio_.openAnalogInput(38);
AI9 = ioio_.openAnalogInput(39);
AI10 = ioio_.openAnalogInput(40);
AI11 = ioio_.openAnalogInput(41);
AI12 = ioio_.openAnalogInput(42);
AI13 = ioio_.openAnalogInput(43);
AI14 = ioio_.openAnalogInput(44);
AI15 = ioio_.openAnalogInput(45);
AI16 = ioio_.openAnalogInput(46);
/*
* for (int i = 0; i < DOA.length; i++) { DOA[i] =
* ioio_.openDigitalOutput(i + 6); }
*/
// for (int i = 0; i < DIA.length; i++) {
// DIA[i] = ioio_.openDigitalInput(i + 18);
// }
// for (int i = 0; i < PWMA.length; i++) {
// PWMA[i] = ioio_.openPwmOutput(i + 27, 10000);
// }
//
// for (int i = 0; i < AIA.length; i++) {
// AIA[i] = ioio_.openAnalogInput(i + 31);
// }
// TWIA[0] = ioio_.openTwiMaster(1, TwiMaster.Rate.RATE_1MHz,
// false);
// TWIA[1] = ioio_.openTwiMaster(2, TwiMaster.Rate.RATE_1MHz,
// false);
// TWIA[2] = ioio_.openTwiMaster(4, TwiMaster.Rate.RATE_1MHz,
// false);
// TWIA[3] = ioio_.openTwiMaster(5, TwiMaster.Rate.RATE_1MHz,
// false);
connStatus = true;
}
/**
* Called repetitively while the IOIO is connected.
*
* @throws ConnectionLostException
* When IOIO connection is lost.
* @throws InterruptedException
*
* @see ioio.lib.util.AbstractIOIOActivity.IOIOThread#loop()
*/
@Override
public void loop() throws ConnectionLostException, InterruptedException {
led_.write(false);
DO1.write(currentDigFrag.digitalIO0Power.isChecked());
DO2.write(currentDigFrag.digitalIO1Power.isChecked());
DO3.write(currentDigFrag.digitalIO2Power.isChecked());
DO4.write(currentDigFrag.digitalIO3Power.isChecked());
DO5.write(currentDigFrag.digitalIO4Power.isChecked());
DO6.write(currentDigFrag.digitalIO5Power.isChecked());
DO7.write(currentDigFrag.digitalIO6Power.isChecked());
DO8.write(currentDigFrag.digitalIO7Power.isChecked());
DO9.write(currentDigFrag.digitalIO8Power.isChecked());
DO10.write(currentDigFrag.digitalIO9Power.isChecked());
DO11.write(currentDigFrag.digitalIO10Power.isChecked());
DO12.write(currentDigFrag.digitalIO11Power.isChecked());
UITask
currentDigFrag.updateDigitalInput(1, !DI1.read());
currentDigFrag.updateDigitalInput(2, !DI2.read());
currentDigFrag.updateDigitalInput(3, !DI3.read());
currentDigFrag.updateDigitalInput(4, !DI4.read());
currentDigFrag.updateDigitalInput(5, !DI5.read());
currentDigFrag.updateDigitalInput(6, !DI6.read());
currentDigFrag.updateDigitalInput(7, !DI7.read());
currentDigFrag.updateDigitalInput(8, !DI8.read());
currentDigFrag.updateDigitalInput(9, !DI8.read());
currentAnFrag.updateAnalogInput(1,AI1.getVoltage());
currentAnFrag.updateAnalogInput(2,AI2.getVoltage());
currentAnFrag.updateAnalogInput(3,AI3.getVoltage());
currentAnFrag.updateAnalogInput(4,AI4.getVoltage());
currentAnFrag.updateAnalogInput(5,AI5.getVoltage());
currentAnFrag.updateAnalogInput(6,AI6.getVoltage());
currentAnFrag.updateAnalogInput(7,AI7.getVoltage());
currentAnFrag.updateAnalogInput(8,AI8.getVoltage());
currentAnFrag.updateAnalogInput(9,AI9.getVoltage());
currentAnFrag.updateAnalogInput(10,AI10.getVoltage());
currentAnFrag.updateAnalogInput(11,AI11.getVoltage());
currentAnFrag.updateAnalogInput(12,AI12.getVoltage());
currentAnFrag.updateAnalogInput(13,AI13.getVoltage());
currentAnFrag.updateAnalogInput(14,AI14.getVoltage());
currentAnFrag.updateAnalogInput(15,AI15.getVoltage());
currentAnFrag.updateAnalogInput(16,AI16.getVoltage());
}
}
到目前为止,这是我用AsyncTask
实现的内容;我有点困惑:
private class UIAsyncTask extends AsyncTask<analogFragment, Float, Void> {
@Override
protected Void doInBackground(analogFragment... params) {
//What do I do in here???
return null;
}
}
注意:这两个类都是内部类。
另请注意:currentDigFrag
和currentAnFrag
只是包含视图的当前Fragment
;特别是ProgressBar
次观看
这是我尝试过的,没有结果:
private class AnalogUpdater extends AsyncTask<AnalogInput, Void, Void> {
// A callback method executed on non UI thread, invoked after
// onPreExecute method if exists
// Takes a set of parameters of the type defined in your class
// implementation. This method will be
// executed on the background thread, so it must not attempt to interact
// with UI objects.
@Override
protected Void doInBackground(AnalogInput... params) {
try {
currentAnFrag.updateAnalogInput(1, AI1.getVoltage());
currentAnFrag.updateAnalogInput(2, AI2.getVoltage());
currentAnFrag.updateAnalogInput(3, AI3.getVoltage());
currentAnFrag.updateAnalogInput(4, AI4.getVoltage());
currentAnFrag.updateAnalogInput(5, AI5.getVoltage());
currentAnFrag.updateAnalogInput(6, AI6.getVoltage());
currentAnFrag.updateAnalogInput(7, AI7.getVoltage());
currentAnFrag.updateAnalogInput(8, AI8.getVoltage());
currentAnFrag.updateAnalogInput(9, AI9.getVoltage());
currentAnFrag.updateAnalogInput(10, AI10.getVoltage());
currentAnFrag.updateAnalogInput(11, AI11.getVoltage());
currentAnFrag.updateAnalogInput(12, AI12.getVoltage());
currentAnFrag.updateAnalogInput(13, AI13.getVoltage());
currentAnFrag.updateAnalogInput(14, AI14.getVoltage());
currentAnFrag.updateAnalogInput(15, AI15.getVoltage());
currentAnFrag.updateAnalogInput(16, AI16.getVoltage());
} catch (ConnectionLostException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
// A callback method executed on UI thread, invoked by the
// publishProgress()
// from doInBackground() method
// Overrider this handler to post interim updates to the UI thread. This
// handler receives the set of parameters
// passed in publishProgress from within doInbackground.
}
}
答案 0 :(得分:1)
因此,您必须了解AsyncTask可以访问UI线程的函数。最常用的是onProgressUpdate。
为了调用此函数,调用publishProgress(Float ... progress)(给它一个Float或一个Floats数组),并在你的onProgressUpdate()函数中更新你需要使用的所有UI。 Flolets数组。
在doInBackground中,你只需将循环逻辑放在这里,存储你需要的变量,在每个循环结束时,或每隔一个循环,或者甚至在暂停循环一段时间之后,你会在我之前说过的方法中调用publishProgress。
您可能想要覆盖的其他方法是onPreExecute()和onPostExecute(),以防您想在doInBackground()执行之前和之后进行任何额外的设置。
http://www.vogella.com/tutorials/AndroidBackgroundProcessing/article.html#concurrency_asynchtask是一个很好的阅读