经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » Android » 查看文章
Android跟随手指移动的控件demo实例
来源:jb51  时间:2021/12/24 8:46:12  对本文有异议

前言

事实上,软件工程的多数苦恼不是源自缺少工具或管理不当,而是因为技术能力本身的缺乏。

今天给大家分享跟随手指移动的控件,demo展示如下。手指到哪这个小马就跑到哪。

请添加图片描述

使用自定义View组件实现demo。

第一步

首先创建一个Android project,我们使用Android studio 自动创建 activity。

第二步:

准备两张图片,一个是大草原背景图片,一个是奔跑的马儿。把这两种图片均放在src/main/res/mipmap-xhdpi文件下

第三步:

在 activity_main 文件下设置布局。一般自定义的组件都是放在帧布局管理器中,将大草原图片作为布局的背景,并且给布局定一个id,因为后面逻辑代码中会用到。详细代码如下:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. android:background="@mipmap/pic1"
  8. android:id="@+id/horse"
  9. tools:context=".MainActivity">

第四步

创建一个java文件,名为:HorseDemo.java ,在这个文件中主要是设定马儿的基本属性,以及实例化画图和位图方法,详细代码如下:

  1. package com.xiaozeng.demo;
  2.  
  3. import android.content.Context;
  4. import android.graphics.Bitmap;
  5. import android.graphics.BitmapFactory;
  6. import android.graphics.Canvas;
  7. import android.graphics.Paint;
  8. import android.view.View;
  9.  
  10. public class HorseDemo extends View {
  11. //设置两个变量
  12. public float horseX,horseY;
  13. //创建构造方法
  14. public HorseDemo(Context context) {
  15. super(context);
  16. horseX = 200;
  17. horseY = 300;
  18. }
  19. //第二步:重写onDraw方法 Ctrl+o
  20.  
  21. @Override
  22. protected void onDraw(Canvas canvas) {
  23. super.onDraw(canvas);
  24. //实例化画图对象
  25. Paint paint = new Paint();
  26. //位图对象
  27. Bitmap bitmap = BitmapFactory.decodeResource(this.getResources(),R.mipmap.pic2);
  28. //回收
  29. canvas.drawBitmap(bitmap,horseX,horseY,paint);
  30. if(bitmap.isRecycled()){
  31. bitmap.recycle();
  32.  
  33. }
  34. }
  35. }

第五步

在 MainActivity 文件中需要获取布局管理器,并增加触摸事件监听器。完整代码如下:

  1. package com.xiaozeng.demo;
  2.  
  3. import androidx.appcompat.app.AppCompatActivity;
  4.  
  5. import android.os.Bundle;
  6. import android.view.MotionEvent;
  7. import android.view.View;
  8. import android.widget.FrameLayout;
  9. import android.widget.ViewAnimator;
  10.  
  11. public class MainActivity extends AppCompatActivity {
  12.  
  13. @Override
  14. protected void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.activity_main);
  17. //获取布局管理器
  18. FrameLayout frameLayout = findViewById(R.id.horse);
  19. //实例化
  20. HorseDemo horseDemo = new HorseDemo(this);
  21. //触摸事件监听器
  22. horseDemo.setOnTouchListener(new View.OnTouchListener() {
  23. @Override
  24. public boolean onTouch(View v, MotionEvent event) {
  25. //坐标
  26. horseDemo.horseX = event.getX();
  27. horseDemo.horseY = event.getY();
  28. //重绘
  29. horseDemo.invalidate();
  30.  
  31. return true;
  32. }
  33. });
  34. frameLayout.addView(horseDemo);
  35. }
  36. }

以上就是完整的demo代码 ??!!!
当然也可以参考小编的github https://github.com/Jenny-Zeng/AndroidDemo/tree/main/Demo1

到此这篇关于Android跟随手指移动的控件demo实例的文章就介绍到这了,更多相关Android控件内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号