iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android自定义控件实现随手指移动的小球
  • 904
分享到

Android自定义控件实现随手指移动的小球

Android 2022-06-06 07:06:50 904人浏览 八月长安
摘要

一个关于自定义控件的小Demo,随着手指移动的小球。 先看下效果图: 实现代码如下: 1.自定义控件类 package com.dc.customview.view;

一个关于自定义控件的小Demo,随着手指移动的小球。
先看下效果图:

实现代码如下:

1.自定义控件类


package com.dc.customview.view;
import Android.content.Context;
import android.graphics.canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
public class DrawCircle extends View {
  //圆的初始位置
  private int x = 100;
  private int y = 100;
  Context context;
  
  public DrawCircle(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    this.context = context;
  }
  
  public DrawCircle(Context context, AttributeSet attrs) {
    super(context, attrs);
    this.context = context;
  }
  
  public DrawCircle(Context context) {
    super(context);
    this.context = context;
  }
  @Override
  protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    // 画笔
    Paint paint = new Paint();
    paint.setColor(Color.RED);
    //绘制圆  
    //cx :圆心的x坐标
    //cy :圆心的y坐标  
    //radius :圆的半径
    //paint :画笔
    canvas.drawCircle(x, y, 20, paint);
  }
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    switch (event.getAction()) {
      case MotionEvent.ACTION_DOWN:
      case MotionEvent.ACTION_MOVE:
      case MotionEvent.ACTION_UP:
        // 获取当前触摸点的x,y坐标
          x = (int) event.getX();
          y = (int) event.getY();
        break;
    }
    //获取屏幕宽高
    WindowManager manager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE);
    int width = manager.getDefaultDisplay().getWidth();
    int heigh = manager.getDefaultDisplay().getHeight();
    //重新绘制圆 ,控制小球不会被移出屏幕
    if(x>=20 && y>=20 && x<=width-20 && y<=heigh-90){
      invalidate();
    }
      // 自己处理触摸事件
      return true;
    }
}

2.引用自定义控件

第一种:xml中引用


<RelativeLayout xmlns:android="Http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent" 
  android:id="@+id/rl">
  <!-- 自定义控件的全类名 -->
  <com.dc.customview.view.DrawCircle
    android:id="@+id/circle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" >
  </com.dc.customview.view.DrawCircle>
</RelativeLayout>

第二种:代码中引用


package com.dc.customview;
import com.dc.customview.view.DrawCircle;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.RelativeLayout;
public class MainActivity extends Activity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    //获取容器
    RelativeLayout container = (RelativeLayout) findViewById(R.id.rl);
    //创建自定义控件
    DrawCircle circle = new DrawCircle(this);
    //添加到容器
    container.addView(circle);
  }
}

以上,将Demo运行到模拟器或手机上,即可实现一个红色的圆,随着手指触摸移动而移动的效果。

您可能感兴趣的文章:Android自定义圆形View实现小球跟随手指移动效果Android实现拖动小球跟随手指移动效果Android自定义view圆并随手指移动Android实现View拖拽跟随手指移动效果Android中View跟随手指移动效果基于Android实现随手指移动的ImageViewAndroid自定义视图实现手指移动轨迹


--结束END--

本文标题: Android自定义控件实现随手指移动的小球

本文链接: https://www.lsjlt.com/news/23778.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作