将RadioButton 换成Button ,类似的在res/layout 中新建brush.xml:

<?xml version=”1.0″ encoding=”utf-8″?>
<LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
android:orientation=”vertical”
android:background=”@drawable/white”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”>
<com.pstreets.graphics2d.GuidebeeGraphics2DView
android:id=”@+id/graphics2dview”
android:layout_weight=”1″
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”/>
<LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
android:layout_width=”wrap_content” android:layout_height=”wrap_content”
android:orientation=”horizontal”

>

<Button android:text=”Pattern”
android:id=”@+id/btnPattern”
android:layout_width=”wrap_content”
android:textColor=”@color/black”
android:checked=”true”
android:layout_height=”wrap_content”>
</Button>
<Button android:text=”Gradients”
android:id=”@+id/btnGradients”
android:layout_width=”wrap_content”
android:textColor=”@color/black”
android:layout_height=”wrap_content”>
</Button>

</LinearLayout>

</LinearLayout>

修改Brushes.java ,完整代码如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 public class Brushes extends Graphics2DActivity implements OnClickListener { private Button btnPattern; private Button btnGradients; public void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.brush); graphic2dView = (GuidebeeGraphics2DView) findViewById(R.id.graphics2dview); btnPattern = (Button) findViewById(R.id.btnPattern); btnGradients = (Button) findViewById(R.id.btnGradients); btnPattern.setOnClickListener( this ); btnGradients.setOnClickListener( this ); } @Override protected void drawImage() { drawPatterns(); } @Override public void onClick(View view) { if (view == btnPattern) { drawPatterns(); } else { drawGradient(); } graphic2dView.refreshCanvas(); } private void drawPatterns() { TextureBrush brush1; TextureBrush brush2; TextureBrush brush3; AffineTransform matrix1 = new AffineTransform(); AffineTransform matrix2 = new AffineTransform(); Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.brick); int [] rgbData = new int [bitmap.getHeight() * bitmap.getWidth()]; bitmap.getPixels(rgbData, 0 , bitmap.getWidth(), 0 , 0 , bitmap.getWidth(), bitmap.getHeight()); brush1 = new TextureBrush(rgbData, bitmap.getWidth(), bitmap.getHeight()); bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.bird); rgbData = new int [bitmap.getHeight() * bitmap.getWidth()]; bitmap.getPixels(rgbData, 0 , bitmap.getWidth(), 0 , 0 , bitmap.getWidth(), bitmap.getHeight()); brush2 = new TextureBrush(rgbData, bitmap.getWidth(), bitmap.getHeight()); brush3 = new TextureBrush(rgbData, bitmap.getWidth(), bitmap.getHeight(), 127 ); matrix2.translate( 50 , 50 ); // Clear the canvas with white color. graphics2D.clear(Color.WHITE); graphics2D.setAffineTransform(matrix1); graphics2D.fillRectangle(brush1, new Rectangle( 20 , 50 , 100 , 100 )); graphics2D.fillOval(brush2, 10 , 10 , 80 , 80 ); graphics2D.setAffineTransform(matrix2); graphics2D.fillOval(brush3, 10 , 10 , 80 , 80 ); } private void drawGradient() { /* The linear gradient color */ LinearGradientBrush brush1; /* The radial gradient color */ RadialGradientBrush brush2; /* The second radial gradient color */ RadialGradientBrush brush3; char [] engText = "Brush" .toCharArray(); FontEx font = FontEx.getSystemFont(); int fontSize = 44 ; int X = 15 ; int Y = 50 ; int [] fractions = new int [] { 13 , 242 }; Color[] colors = new Color[] { new Color( 0xffff6600 ), new Color( 0xffffff66 ) }; brush1 = new LinearGradientBrush( 50 , 50 , 150 , 125 , fractions, colors, Brush.NO_CYCLE); fractions = new int [] { 13 , 128 , 255 }; colors = new Color[] { new Color( 0xffff6600 ), new Color( 0xffffff66 ), new Color( 0xffff6600 ) }; brush2 = new RadialGradientBrush( 90 , 100 , 50 , fractions, colors); fractions = new int [] { 0 , 255 }; colors = new Color[] { new Color( 0xFFFFFF00 ), new Color( 0xFF000000 ) }; brush3 = new RadialGradientBrush( 50 , 50 , 100 , fractions, colors); // Clear the canvas with white color. graphics2D.clear(Color.white); graphics2D.fillRectangle(brush1, new Rectangle( 10 , 75 , 120 , 80 )); Pen pen = new Pen(brush2, 8 ); graphics2D.drawOval(pen, 20 , 60 , 100 , 50 ); graphics2D.setDefaultBrush(brush3); pen = new Pen(brush2, 2 ); graphics2D.setDefaultPen(pen); graphics2D.drawChars(font, fontSize, engText, 0 , engText.length, X, Y); } }

介绍了RadioButton和Button 后,这时应该对使用Android提供的控件的用法有了基本的认识。 控件提供了onClick(),onLongClick(),onFocusChange(),onKey(),onTouch(),onCreateContextMenu()等多种事件以相应用户。用多种方法来处理用户事件。一种是示例代码同过Activity实现OnClickListener接口,再有是采用如下代码为Button支持事件处理方法:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 // Create an anonymous implementation of OnClickListenerprivate OnClickListener mCorkyListener = new OnClickListener() { public void onClick(View v) { // do something when the button is clicked } }; protected void onCreate(Bundle savedValues) { ... // Capture our button from layout Button button = (Button)findViewById(R.id.corky); // Register the onClick listener with the implementation above button.setOnClickListener(mCorkyListener); ... }

在创建自定义控件时,也可以重载onKeyDown(int, KeyEvent),onKeyUp(int, KeyEvent) ,onTouchEvent(MotionEvent)等来处理用户事件。

更多相关文章

  1. Android屏蔽HOME键
  2. 安卓自定义流式布局
  3. android 保持屏幕长亮及解锁的方法
  4. android 中动态创建控件
  5. Android下MP3播放器的实现源代码01
  6. Android(安卓)控件之一:Button 按钮
  7. Android(安卓)获取屏幕尺寸实例代码
  8. Android之checkbox使用
  9. Android(安卓)实现Activity后台运行

随机推荐

  1. Android(安卓)Studio如何更换包名(包括代
  2. android:taskAffinity使用详解
  3. 深入理解Activity启动模式
  4. android studio 修改包名,双开一起安装
  5. ROSJava安装和在Android中使用ROS
  6. 一触即发——App启动优化最佳实践
  7. [Android] Gradle 安装
  8. Android(安卓)Launcher 研究学习
  9. Drawable资源——LevelListDrawable 级列
  10. android一个小网络图片查看器