When I run my AsyncTask class on my Samsung galaxy S3(4.1.1) it runs perfectly fine but when I run it on my HTC Android(2.3.4) I get the below error. What is the issue here?
Here is the class.
public class enemyHandler extends AsyncTask<String, Integer, String>
{
@Override
protected String doInBackground(String... arg0) {
if(System.currentTimeMillis() - lastSpawn >= 2000)
{
Enemy x = new Enemy(SCREEN_WIDTH, SCREEN_HEIGHT, enemy.getHeight());
enemies.add(x);
lastSpawn = System.currentTimeMillis();
}
for(int i = 0; i < enemies.size(); i++)
{
Enemy tempE = enemies.get(i);
if(tempE.x <= 0 - enemy.getWidth())
enemies.remove(tempE);
}
return null;
}
}
Logcat output:
03-14 18:04:53.656: E/AndroidRuntime(4279): FATAL EXCEPTION: Thread-12
03-14 18:04:53.656: E/AndroidRuntime(4279): java.lang.ExceptionInInitializerError
03-14 18:04:53.656: E/AndroidRuntime(4279): at com.jister13.plane.Main$SView.run(Main.java:188)
03-14 18:04:53.656: E/AndroidRuntime(4279): at java.lang.Thread.run(Thread.java:1027)
03-14 18:04:53.656: E/AndroidRuntime(4279): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
03-14 18:04:53.656: E/AndroidRuntime(4279): at android.os.Handler.<init>(Handler.java:121)
03-14 18:04:53.656: E/AndroidRuntime(4279): at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
03-14 18:04:53.656: E/AndroidRuntime(4279): at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421)
03-14 18:04:53.656: E/AndroidRuntime(4279): at android.os.AsyncTask.<clinit>(AsyncTask.java:152)
03-14 18:04:53.656: E/AndroidRuntime(4279): ... 2 more
SOLUTION:
I was able to solve this problem by calling my
AsyncTask().execute("");
in the onCreate() so as to create the class itself and then recalling it where I wanted it to be run...