In order to have responsive UI use AsyncTask.
Here is one example.
content_main.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:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" app:layout_behavior="@string/appbar_scrolling_view_behavior" tools:context="com.example.stanko.myapplication.MainActivity" tools:showIn="@layout/activity_main"> <EditText android:id="@+id/myCounter" android:layout_width="match_parent" android:layout_height="1200px" /> <Button android:layout_width="match_parent" android:layout_height="match_parent" android:layout_below="@+id/myCounter" android:text="Start" android:onClick="startCounter"/> </RelativeLayout>
MainActivity.java:
public class fillEdit extends AsyncTask<Void, String, String> { @Override protected String doInBackground(Void... params) { for (Integer i=0; i<10000; i++) { try { Thread.currentThread().sleep(60); } catch (InterruptedException e) { e.printStackTrace(); } publishProgress(i.toString()); } return null; } @Override protected void onProgressUpdate (String... result) { EditText myCounter = (EditText) findViewById(R.id.myCounter); myCounter.append(result[0]); myCounter.append("\n"); } } public void startCounter (View view) { new fillEdit().execute(); }
Here note:
try {
Thread.currentThread().sleep(60);
} catch (InterruptedException e) {
e.printStackTrace();
}
I needed to slow down code execution to make UI responsive, I also needed try / catch block because otherwise I would receive error:
Error:(51, 49) error: unreported exception InterruptedException; must be caught or declared to be thrown
Also, note how I am adding new line:
myCounter.append("\n");