android 自定义View使用

来源:互联网 发布:ajax post json data 编辑:程序博客网 时间:2024/06/06 14:00

需求:自定义view组件,实现跟随手指的小兔子,或者其他图片


包含四个文件:main.xml,RabbitView,MainActivity,androidmain.xml

1.

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" 
    android:background="@drawable/background"
    android:id="@+id/mylayout"
    >
    
</FrameLayout>


2.

public class RabbitView extends View {


public float bitmapX;
public float bitmapY;

public RabbitView(Context context) {
super(context);
bitmapX = 750;
bitmapY = 500;

}


@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
Paint paint = new Paint();
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.rabbit);
canvas.drawBitmap(bitmap, bitmapX, bitmapY, paint);
if (bitmap.isRecycled()) {
bitmap.recycle();
}

}
}


3.

public class MainActivity extends Activity {


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
FrameLayout frameLayout = (FrameLayout) findViewById(R.id.mylayout);
final RabbitView rabbit = new RabbitView(MainActivity.this);

rabbit.setOnTouchListener(new OnTouchListener() {

@Override
public boolean onTouch(View v, MotionEvent event) {
rabbit.bitmapX = event.getX();
rabbit.bitmapY = event.getY();
rabbit.invalidate();
return true;
}
});

frameLayout.addView(rabbit);
}


}

4.配置文件略



0 0
原创粉丝点击