Doing background stuff on a different UI

和自甴很熟 提交于 2019-12-25 18:12:51

问题


I have designed an app that gets the network information and updates the UI every 5 seconds. It is advised to do the background processes on a separate thread than the UI thread, and I did so...but I still get an error that:

"I/Choreographer﹕ Skipped 3730 frames! The application may be doing too much work on its main thread."

Why is that? Here's my code

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    wifiTextView = (TextView)findViewById(R.id.wifi_textView);
    ipTextView = (TextView)findViewById(R.id.ip_val_textView);
    // and so on

    //Updating the UI every mInterval seconds, using a separate thread than UI thread
    Thread backgroundThread = new Thread() {
        @Override
        public void run() {
            try {
                while (!isInterrupted()) {
                    Thread.sleep(mInterval);
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            //Log.d(DEBUG_TAG, "run(): Background thread");
                            MyNetwork network = new MyNetwork(getApplicationContext());  // passing the context
                            updateUI(network);
                        }
                    });
                }
            } catch (InterruptedException e) {
                wifiTextView.setText("Exception: Please Close and Restart the App");
            }
        }
    };
    backgroundThread.start();

}

In the same MainActivity class, I have this private function:

 private void updateUI(MyNetwork network){
    // Handles updating the textviews in the UI
    //Log.d(DEBUG_TAG, "updateUI(DeepstreamNetwork)");

    if (network.isConnected()){
        wifiTextView.setText(R.string.wifi_is_on);
        wifiTextView.setTextColor(Color.GREEN);

        ipTextView.setText(network.getIpAddress());

    else {
        wifiTextView.setText(R.string.wifi_is_off);
        wifiTextView.setTextColor(Color.RED);

        ipTextView.setText("N/A");

    }
}

UPDATE

So, I have updated my MainActivity class to have this MyAsyncTask method to handle background work...here's my code:

private class MyAsyncTask extends AsyncTask<Void, Void, MyNetwork> {
    @Override
    protected void onPostExecute(MyNetwork network) {
        updateUI(network);
    }

    @Override
    protected MyNetwork doInBackground(Void... params) {
        MyNetwork network = new MyNetwork(getApplicationContext());  // passing the context
        return network;
    }

    @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
    }
}

Two issues:

1) how do I force it to do this background task every 5 seconds. Since the network status changes every few secs (disconnection etc...), so I want it to update the UI respectively.

2) should I call it like this in MainActivity: new MyAsyncTask().execute();

Thanks all


回答1:


I dont know why you called it Thread backgroundThread = new Thread() because runOnUiThread() is really the main Thread.

You should try this in an asynctask where you only update the UI in onPostExecute()

EDIT:

private class MyAsyncTask extends AsyncTask<Void, Void, String> {

    private MyNetwork network;

    @Override
    protected void onPreExecute() {
        this.network = new MyNetwork(getApplicationContext()); 
    }

    @Override
    protected String doInBackground(Void... params) {
        return network.getIpAddress();
    }

    @Override
    protected void onPostExecute(String ipAddress) {
        if (this.network.isConnected()){
            wifiTextView.setText(R.string.wifi_is_on);
            wifiTextView.setTextColor(Color.GREEN);
            ipTextView.setText(ipAddress);
        else {
            wifiTextView.setText(R.string.wifi_is_off);
            wifiTextView.setTextColor(Color.RED);
            ipTextView.setText("N/A");
        }
    }

    @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
    }
}


来源:https://stackoverflow.com/questions/34734133/doing-background-stuff-on-a-different-ui

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!