本节讲解使用SurfaceView组件绘制动画的方法。SurfaceView类作为View类的子类,进行绘图时能够比一般的View组件更快,所以我们在Android游戏、视频等对流畅度和帧速要求较高的应用中经常会见到SurfaceView的身影。
本文通过实例讲解的方式来介绍SurfaceView的使用方法,此实例实现的是一个能发送莫尔斯码的灯塔。下面是详细步骤,代码中的注释可以帮助大家理解。
1、创建项目Lesson25_Morse,启动Activity名字叫MainActivity.java。
2、创建一个莫尔斯码的工具类Morse.java。
Java代码
- package basic.android.lesson37;
-
- import java.util.HashMap;
- import java.util.Map;
-
- public class Morse {
-
- public static Map<STRING string ,> standardMorseCharactersMap = new HashMap</STRING><STRING string ,>();
-
- static {
- standardMorseCharactersMap.put("a", ".-");
- standardMorseCharactersMap.put("b", "-...");
- standardMorseCharactersMap.put("c", "-.-.");
- standardMorseCharactersMap.put("d", "-..");
- standardMorseCharactersMap.put("e", ".");
- standardMorseCharactersMap.put("f", "..-.");
- standardMorseCharactersMap.put("g", "--.");
- standardMorseCharactersMap.put("h", "....");
- standardMorseCharactersMap.put("i", "..");
- standardMorseCharactersMap.put("j", ".---");
- standardMorseCharactersMap.put("k", "-.-");
- standardMorseCharactersMap.put("l", ".-..");
- standardMorseCharactersMap.put("m", "--");
- standardMorseCharactersMap.put("n", "-.");
- standardMorseCharactersMap.put("o", "---");
- standardMorseCharactersMap.put("p", ".--.");
- standardMorseCharactersMap.put("q", "--.-");
- standardMorseCharactersMap.put("r", ".-.");
- standardMorseCharactersMap.put("s", "...");
- standardMorseCharactersMap.put("t", "-");
- standardMorseCharactersMap.put("u", "..-");
- standardMorseCharactersMap.put("v", "...-");
- standardMorseCharactersMap.put("w", ".--");
- standardMorseCharactersMap.put("x", "-..-");
- standardMorseCharactersMap.put("y", "-.--");
- standardMorseCharactersMap.put("z", "--..");
-
- standardMorseCharactersMap.put("0", "-----");
- standardMorseCharactersMap.put("1", ".----");
- standardMorseCharactersMap.put("2", "..---");
- standardMorseCharactersMap.put("3", "...--");
- standardMorseCharactersMap.put("4", "....-");
- standardMorseCharactersMap.put("5", ".....");
- standardMorseCharactersMap.put("6", "-....");
- standardMorseCharactersMap.put("7", "--...");
- standardMorseCharactersMap.put("8", "---..");
- standardMorseCharactersMap.put("9", "----.");
-
- standardMorseCharactersMap.put(".", ".-.-.-");
- standardMorseCharactersMap.put("-", "-....-");
- standardMorseCharactersMap.put(",", "--..--");
- standardMorseCharactersMap.put("?", "..--..");
- standardMorseCharactersMap.put("/", "-..-.");
- standardMorseCharactersMap.put(";", "-.-.-.");
- standardMorseCharactersMap.put("(", "-.--.");
- standardMorseCharactersMap.put(")", "-.--.-");
- standardMorseCharactersMap.put("@", ".--.-.");
- standardMorseCharactersMap.put("*", "...-.-");
- standardMorseCharactersMap.put("+", ".-.-.");
- standardMorseCharactersMap.put("%", ".-...");
- standardMorseCharactersMap.put("\\", "---...");
- standardMorseCharactersMap.put("\"", ".-..-.");
- standardMorseCharactersMap.put("'", ".----.");
- standardMorseCharactersMap.put("!", "=---.");
- standardMorseCharactersMap.put("$", "...-..-");
- standardMorseCharactersMap.put(" ", "/");
- }
-
- public static String morseEncoder(String input) {
- String output = "";
- for (char c : input.toCharArray()) {
- output += standardMorseCharactersMap.get(String.valueOf(c)) + " ";
- }
- return output;
- }
-
- public static void main(String[] args) {
- String input = "yao mu yang";
- String output = Morse.morseEncoder(input);
- System.out.println(output);
- }
-
- }</STRING>
3、布局文件main.xml 的内容如下:
XML/HTML代码
- <?xml version="1.0" encoding="utf-8"?>
- <LINEARLAYOUT xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/LinearLayout01" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent">
-
- <TEXTVIEW android:id="@+id/TextView01" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="输入:">
- </TEXTVIEW>
-
- <EDITTEXT android:id="@+id/EditText01" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="">
- </EDITTEXT>
-
- <BUTTON type=submit android:id="@+id/Button01" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="转换">
- </BUTTON>
-
- <TEXTVIEW android:id="@+id/TextView02" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="输出:">
- </TEXTVIEW>
-
- <EDITTEXT android:id="@+id/EditText02" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="" android:editable="false">
- </EDITTEXT>
-
- <BUTTON type=submit android:id="@+id/Button02" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="发送信号">
- </BUTTON>
- </LINEARLAYOUT>
4、MainActivity.java的内容如下:
Java代码
- package basic.android.lesson37;
-
- import android.app.Activity;
- import android.content.Context;
- import android.graphics.Canvas;
- import android.graphics.Color;
- import android.graphics.Paint;
- import android.os.Bundle;
- import android.util.Log;
- import android.view.SurfaceHolder;
- import android.view.SurfaceView;
- import android.view.View;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.LinearLayout;
-
- public class MainActivity extends Activity {
- private LinearLayout layout;
-
-
- char[] chars;
-
- int count = 0;
-
- boolean flag = false;
-
- boolean loop = false;
-
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
-
-
- final Button b1 = (Button) findViewById(R.id.Button01);
- final Button b2 = (Button) findViewById(R.id.Button02);
-
- final EditText et1 = (EditText) findViewById(R.id.EditText01);
- final EditText et2 = (EditText) findViewById(R.id.EditText02);
-
- layout = (LinearLayout) findViewById(R.id.LinearLayout01);
-
-
- b1.setOnClickListener(new View.OnClickListener(){
-
- @Override
- public void onClick(View v) {
- String text = Morse.morseEncoder(et1.getText().toString());
- et2.setText(text);
- }
- });
-
-
- b2.setOnClickListener(new View.OnClickListener() {
-
- @Override
- public void onClick(View v) {
-
- if (et2.getText() != null && et2.getText().toString().length() > 0) {
-
- chars = et2.getText().toString().toCharArray();
-
- count = chars.length;
-
- LightView light = new LightView(MainActivity.this);
-
- layout.addView(light);
- }
- }
- });
- }
-
-
- class LightView extends SurfaceView {
-
-
- SurfaceHolder holder;
-
-
- public LightView(Context context) {
- super(context);
-
-
- holder = this.getHolder();
-
- holder.addCallback(new SurfaceHolder.Callback() {
-
-
- class LightThread implements Runnable {
-
- @Override
- public void run() {
-
- while (loop) {
-
- if (count > 0) {
- Log.i("yao", "" + count);
- String s = String.valueOf(chars[chars.length - count]);
-
- Canvas canvas = holder.lockCanvas(null);
-
- Paint paint = new Paint();
- paint.setAntiAlias(true);
-
-
- paint.setColor(Color.BLACK);
- canvas.drawRect(0, 0, 480, 480, paint);
-
-
- if(flag){
- sleep(2);
- paint.setColor(Color.BLACK);
- }else{
-
- if (s.equalsIgnoreCase(".")) {
- sleep(2);
- paint.setColor(Color.YELLOW);
- } else if(s.equalsIgnoreCase("-")) {
-
- sleep(4);
- paint.setColor(Color.YELLOW);
- }else if(s.equalsIgnoreCase(" ")){
-
- sleep(2);
- paint.setColor(Color.BLACK);
- }else if(s.equalsIgnoreCase("/")){
-
- sleep(2);
- paint.setColor(Color.BLACK);
- }else{
-
- sleep(2);
- paint.setColor(Color.RED);
- }
- count--;
- }
-
- canvas.drawCircle(250.0f, 200.0f, 100, paint);
-
-
- flag = !flag;
-
-
- holder.unlockCanvasAndPost(canvas);
- }
-
- }
-
- }
-
-
- public void sleep(int time){
- try {
- Thread.sleep(time*80);
- } catch (Exception e) {
-
- }
- }
- }
-
- @Override
- public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
-
- }
-
- @Override
- public void surfaceCreated(SurfaceHolder holder) {
-
- new Thread(new LightThread()).start();
- }
-
- @Override
- public void surfaceDestroyed(SurfaceHolder holder) {
- loop = false;
- }
- });
-
- loop = true;
-
- }
- }
- }
5、编译并运行程序,查看结果:
好了,本讲就到这里,下次再见。