Android自定义view制作抽奖转盘

所属分类: 软件编程 / Android 阅读数: 51
收藏 0 赞 0 分享

本文实例为大家分享了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.getX() > mDownX + 10 ||
   event.getY() < mDownY -10 ||
   event.getY() > mDownY + 10) ){
   isTouchInSide = false;
  } else if (event.getAction() == MotionEvent.ACTION_UP &&
   event.getX() > mDownX -10 &&
   event.getX() < mDownX + 10 &&
   event.getY() > mDownY -10 &&
   event.getY() < mDownY + 10 &&
   isTouchInSide) {
   float degrees = (float) (720 + Math.random() * 1000);
   RotateAnimation rotateAnimation = new RotateAnimation(0, -degrees, 250, 250);
   rotateAnimation.setDuration(5000);
   rotateAnimation.setFillAfter(true);
   customTurntableView.startAnimation(rotateAnimation);
  }
  isTouchInSide = false;
  return false;
  }
 });
 }
}

对应的布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/ll"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".MainActivity">

 <com.bawei.myapplication.turntable.CustomTurntableView
 android:id="@+id/custom"
 android:layout_width="wrap_content"
 android:layout_height="500dp"
 />

 <com.bawei.myapplication.turntable.CustomTurntableInsideView
 android:id="@+id/custom_inside"
 android:layout_width="wrap_content"
 android:layout_height="500dp"
 app:text="开始"
 android:background="#3300ff00" />
</RelativeLayout>

自定义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 < mCircleCount; i++){
  //按角标单双号设置扇形颜色,
  if(i % 2 == 0 ){
  mPaint.setColor(Color.BLUE);
  }else{
  mPaint.setColor(Color.GREEN);
  }
  canvas.drawArc(rectF, mStartAngle, 60, true, mPaint);
  //设置转盘上的文字
  mPaint.setColor(Color.BLACK);
  mPaint.setTextSize(20);
  Path path = new Path();
  path.addArc(rectF,mStartAngle+20,60);
  canvas.drawTextOnPath(textColor[i],path,-10,40,mPaint);
  mStartAngle += 60;
 }
 }
}

自定义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

<?xml version="1.0" encoding="utf-8"?>
<resources>
 <!-- name为想要调用这个属性的类名即可 -->

 <declare-styleable name="CustomTurntableView">
 <!-- name为属性的名字,可以随意起,只要符合规则看得懂 -->
 <!-- format为属性内容的类型 -->
 <attr name="text" format="string"></attr>
 </declare-styleable>
</resources>

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

更多精彩内容其他人还在看

使用ViewPager实现android软件使用向导功能实现步骤

现在的大部分android软件,都是使用说明,就是第一次使用该软件时,会出现向导,可以左右滑动,然后就进入应用的主界面了,下面我们就实现这个功能
收藏 0 赞 0 分享

android在异步任务中关闭Cursor的代码方法

android在异步任务中如何关闭Cursor?在我们开发应用的时候,很多时候会遇到这种问题,下面我们就看看代码如何实现
收藏 0 赞 0 分享

Android自定义桌面功能代码实现

android自定义桌面其实很简单,看一个例子就明白了
收藏 0 赞 0 分享

android将图片转换存到数据库再从数据库读取转换成图片实现代码

有时候我们想把图片存入到数据库中,尽管这不是一种明智的选择,但有时候还是不得以会用到,下面说说将图片转换成byte[]数组存入到数据库中去,并从数据库中取出来转换成图像显示出来
收藏 0 赞 0 分享

TextView显示系统时间(时钟功能带秒针变化

用System.currentTimeMillis()可以获取系统当前的时间,我们可以开启一个线程,然后通过handler发消息,来实时的更新TextView上显示的系统时间,可以做一个时钟的功能
收藏 0 赞 0 分享

Android用ListView显示SDCard文件列表的小例子

本文简单实现了用ListView显示SDCard文件列表,目录的回退等功能暂不讨论,获取文件列表,files即为所选择目录下的所有文件列表
收藏 0 赞 0 分享

Android拦截外拨电话程序示例

这篇文章主要介绍了Android拦截外拨电话的示例,大家参考使用吧
收藏 0 赞 0 分享

通过Html网页调用本地安卓(android)app程序代码

如何使用html网页和本地app进行传递数据呢?经过研究,发现还是有方法的,总结了一下,大致有一下几种方式
收藏 0 赞 0 分享

android Textview文字监控(Textview使用方法)

以手机号充值为例,当用户输入最后一位数时候,进行汇率的变换,本文就实现类似这样的功能
收藏 0 赞 0 分享

Android ListView长按弹出菜单二种实现方式示例

这篇文章主要介绍了Android ListView长按弹出菜单的方法,大家参考实现
收藏 0 赞 0 分享
查看更多