热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android自定义view制作抽奖转盘

这篇文章主要为大家详细介绍了Android自定义view制作抽奖转盘,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android自定义view制作抽奖转盘的具体代码,供大家参考,具体内容如下

效果图

TurntableActivity

package com.bawei.myapplication.turntable;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.RotateAnimation;

import com.bawei.myapplication.R;
import com.bawei.myapplication.turntable.CustomTurntableView;

/**
 * 转盘
 * @author hasee
 */
public class TurntableActivity extends AppCompatActivity {

 CustomTurntableView customTurntableView;
 boolean isTouchInSide = false;
 float mDownX, mDownY;


 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_turntable);

 initView();
 }

 private void initView() {
 customTurntableView = findViewById(R.id.custom);
// findViewById(R.id.custom_inside).setOnClickListener(new View.OnClickListener() {
//  @Override
//  public void onClick(View v) {
//  float degrees = (float)(720 + Math.random() * 1000);
//  RotateAnimation rotateAnimation = new RotateAnimation(0, -degrees, 450, 450);
//  rotateAnimation.setDuration(5000);
//  rotateAnimation.setFillAfter(true);
//  customCircleView.startAnimation(rotateAnimation);
//  }
// });

 findViewById(R.id.custom_inside).setOnTouchListener(new View.OnTouchListener() {
  @Override
  public boolean onTouch(View v, MotionEvent event) {
  if (event.getAction() == MotionEvent.ACTION_DOWN &&
   event.getX() > 200 &&
   event.getX() <300 &&
   event.getY() > 200 &&
   event.getY() <300) {
   isTouchInSide = true;
   mDownX = event.getX();
   mDownY = event.getY();
   return true;
  }else if(event.getAction() == MotionEvent.ACTION_MOVE && (
   event.getX()  mDownX + 10 ||
   event.getY()  mDownY + 10) ){
   isTouchInSide = false;
  } else if (event.getAction() == MotionEvent.ACTION_UP &&
   event.getX() > mDownX -10 &&
   event.getX()  mDownY -10 &&
   event.getY() 

对应的布局

<&#63;xml version="1.0" encoding="utf-8"&#63;>


 

 

自定义CustomTurntableView继承view

package com.bawei.myapplication.turntable;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.RectF;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;

/**
 * 这里是画转盘的
 * @author hasee
 */
public class CustomTurntableView extends View{
 Paint mPaint;
 int mCircleCount = 6;
 float mStartAngle = 0;

 RectF rectF;

 public CustomTurntableView(Context context) {
 super(context);
 init();
 }

 public CustomTurntableView(Context context, @Nullable AttributeSet attrs) {
 super(context, attrs);
 init();
 }

 private void init(){
 mPaint = new Paint();
 mPaint.setColor(Color.BLUE);
 mPaint.setStrokeWidth(10);
 mPaint.setTextSize(60);
 mPaint.setStyle(Paint.Style.FILL);

 rectF = new RectF();
 rectF.top = 100;
 rectF.left = 100;
 rectF.right = 400;
 rectF.bottom = 400;
 }
 String[] textColor = {"一 等 奖","二 等 奖","三 等 奖","四 等 奖","五 等 奖","六 等 奖"};
 @Override
 protected void onDraw(Canvas canvas) {
 super.onDraw(canvas);
 for(int i = 0; i 

自定义CustomTurntableInsideView继承view

package com.bawei.myapplication.turntable;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RectF;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;

import com.bawei.myapplication.R;

/**
 * 转盘中间开始按钮和指针
 * @author hasee
 */
public class CustomTurntableInsideView extends View {
 /**
 * 画笔
 */
 Paint mPaint;
 RectF mRectF;
 String mStr;

 public CustomTurntableInsideView(Context context) {
 super(context);
 init();
 }

 public CustomTurntableInsideView(Context context, @Nullable AttributeSet attrs) {
 super(context, attrs);

 //自定义属性,如何添加自定义属性如下(考点)
 //第一步:在values文件夹下创建attrs.xml
 //第二步:详见attrs.xml文件内部
 //第三步:在所在的布局文件的根layout中添加xmlns:app="http://schemas.android.com/apk/res-auto"
 //第四步:在布局文件的控件中添加app:"你在attrs中设置的attr name"="你的值"
 //第五步:调用下面这句话,最后的为R.styleable.你在attrs中设置的declare-styleable name
 TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.CustomTurntableView);
 //第六步:调用下面这句话,根据你在attrs中设置的format,选择getXXX方法,
 //入参为 R.styleable. 加上 你在attrs中设置的declare-styleable name 加上 _ 加上 你在attrs中设置的attr name
 mStr = typedArray.getString(R.styleable.CustomTurntableView_text);
 init();
 }

 private void init() {
 //以下注释请看CustomBingView里面
 mPaint = new Paint();
 mPaint.setColor(Color.RED);
 mPaint.setStrokeWidth(10);
 mPaint.setTextSize(20);
 mPaint.setStyle(Paint.Style.FILL);

 mRectF = new RectF();
 mRectF.top = 50;
 mRectF.bottom = 300;
 mRectF.right = 300;
 mRectF.left = 200;
 }

 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
 super.onMeasure(widthMeasureSpec, heightMeasureSpec);

// setMeasuredDimension(300, 300);
 }

 @Override
 protected void onDraw(Canvas canvas) {
 super.onDraw(canvas);

 //设置画笔颜色为黑色,
 mPaint.setColor(Color.BLACK);
 //画出指针,用一个扇形,然后盖住后面补分来简单表示
 canvas.drawArc(mRectF, 60, 60, true, mPaint);

 mPaint.setColor(Color.RED);
 //画一个红色的圆形,就是中间的大按钮
 canvas.drawCircle(250, 250, 50, mPaint);

 mPaint.setColor(Color.BLACK);
 //添加按钮上的文字
 canvas.drawText(mStr, 230, 260, mPaint);

 //画三角,第一步,创建路径
// Path path = new Path();
 //第二步,moveTo第一个顶点
// path.moveTo(300, 300);
 //后续相继lineTo其他顶点
// path.lineTo(300, 400);
// path.lineTo(400, 400);
 //闭合
// path.close();
// 画
// canvas.drawPath(path, mPaint);
 }
}

自定义属性attrs.xml

<&#63;xml version="1.0" encoding="utf-8"&#63;>

 

 
 
 
 
 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持,关注公众号的更多精彩内容。


推荐阅读
  • 本文介绍了Android开发中Intent的基本概念及其在不同Activity之间的数据传递方式,详细展示了如何通过Intent实现Activity间的跳转和数据传输。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
  • 优化 Android 按钮状态下的背景和文本颜色变化
    本文介绍如何通过 Android 的 Selector 实现按钮在不同状态下(如按压)的背景和文本颜色动态变化。我们将详细讲解实现步骤,并提供完整的代码示例。 ... [详细]
  • 本文详细介绍超文本标记语言(HTML)的基本概念与语法结构。HTML是构建网页的核心语言,通过标记标签描述页面内容,帮助开发者创建结构化、语义化的Web页面。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • HDU 1394:线段树优化求解逆序对问题
    本文介绍如何使用线段树高效求解排列中的逆序对问题。通过单点增减和区间求和操作,线段树能够快速处理此类问题,并提供了一种替代树状数组的解决方案。 ... [详细]
  • 本文探讨了在Windows Server 2008环境下配置Tomcat使用80端口时遇到的问题,包括端口被占用、多项目访问失败等,并提供详细的解决方法和配置建议。 ... [详细]
  • 本文详细介绍了Java Web应用程序中的过滤器(Filter)功能,包括其作用、实现方式及配置方法。过滤器可以在请求到达目标资源之前对其进行预处理,并在响应返回给客户端之前进行后处理。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 分享一个简化版的Silverlight链接图项目:Link Map Simplified
    本文介绍了一个使用Silverlight开发的可视化工具,主要用于展示和操作复杂的实体关系图(Graph)。该工具在犯罪调查系统中得到了广泛应用,帮助用户直观地获取和理解相关信息。 ... [详细]
  • 探讨如何从数据库中按分组获取最大N条记录的方法,并分享新年祝福。本文提供多种解决方案,适用于不同数据库系统,如MySQL、Oracle等。 ... [详细]
  • 本文介绍了ArcXML配置文件的分类及其在不同服务中的应用,详细解释了地图配置文件的结构和功能,包括其在Image Service、Feature Service以及ArcMap Server中的使用方法。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文详细介绍了 RosPack 类的功能和用法,探讨了其在 ROS 系统中的重要作用。RosPack 类提供了类似于终端命令 rospack 的功能,能够方便地查询和管理 ROS 包的相关信息。 ... [详细]
  • 本文探讨了如何使用自增和自减运算符遍历二维数组中的元素。通过实例详细解释了指针与二维数组结合使用的正确方法,并解答了常见的错误用法。 ... [详细]
author-avatar
深圳市互联网大会
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有