data:image/s3,"s3://crabby-images/96948/96948bd2ec6a63b7219703a5f318f0999419944b" alt=""
This exercise extends from the previous article, AndroidRunnable, with Runnable Thread.
Save the four graphics, used to form the animation of a rotating arrow, in the /res/drawable/ folder.
data:image/s3,"s3://crabby-images/61834/61834e613155d4a43f10da3fd2d2cfa9d420f025" alt=""
data:image/s3,"s3://crabby-images/2deae/2deae62b5936fc6c9c90eb42811c4c28cd3ed90e" alt=""
data:image/s3,"s3://crabby-images/b578f/b578ff4e0f6a1bf6a23ddc73ce3d5ff02fee8e3f" alt=""
data:image/s3,"s3://crabby-images/2ecd1/2ecd1b3fad7482648b197cc4aa8932a6fd2523d2" alt=""
Add a ImageView in main.xml to display the animation.
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello"
/>
<TextView
android:id="@+id/i"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
/>
<ImageView
android:id="@+id/myImageView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="center"
/>
</LinearLayout>
Modify update_i() to change i, and load ViewImage with arrow_01, arrow_02, arrow_03 and arrow_04 one by one.
package com.exercise.AndroidRunnable;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.ImageView;
import android.widget.TextView;
public class AndroidRunnable extends Activity{
int i = 0;
TextView myi;
ImageView MyImageView;
Handler handler = new Handler(){
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
update_i();
}
};
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
myi =(TextView)findViewById(R.id.i);
MyImageView = (ImageView)findViewById(R.id.myImageView);
}
@Override
protected void onStart() {
// TODO Auto-generated method stub
super.onStart();
Thread myThread=new Thread(new Runnable() {
public void run() {
while(true){
try {
handler.sendMessage(handler.obtainMessage());
Thread.sleep(1000);
}
catch (Throwable t) {
}
}
}
});
myThread.start();
}
private void update_i()
{
switch(i){
case 0:
i++;
MyImageView.setImageResource(R.drawable.arrow_01);
break;
case 1:
i++;
MyImageView.setImageResource(R.drawable.arrow_02);
break;
case 2:
i++;
MyImageView.setImageResource(R.drawable.arrow_03);
break;
case 3:
i = 0;
MyImageView.setImageResource(R.drawable.arrow_04);
break;
}
myi.setText(String.valueOf(i));
}
}
AndroidRunnable.java can be downloaded heredata:image/s3,"s3://crabby-images/63f44/63f445b515f226266ae797f5051cac03d0294ebe" alt=""
For sure, it's not a good practice to implement animation. It is used to show the implementation of Runnable Thread, and Handle.
Here is another article about Animation background, using animation-list and AnimationDrawable.
No comments:
Post a Comment