Android实现九宫格抽奖

本文实例为大家分享了Android实现九宫格抽奖的具体代码,供大家参考,具体内容如下

package cq.cake.luckdraw;

import android.graphics.Color;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.widget.TextView;

import java.util.LinkedList;
import java.util.List;
import java.util.Random;

public class MainActivity extends AppCompatActivity {
    private TextView tv1;
    private TextView tv2;
    private TextView tv3;
    private TextView tv4;
    private TextView tvStart;
    private TextView tv5;
    private TextView tv6;
    private TextView tv7;
    private TextView tv8;
    private TextView tvNotice;

    private List<TextView> views = new LinkedList<>();//所有的视图
    private int timeC= 100;//变色时间间隔
    private int lightPosition = 0;//当前亮灯位置,从0开始
    private int runCount = 10;//需要转多少圈
    private int lunckyPosition = 4;//中奖的幸运位置,从0开始

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

    private void init() {
        tv1 = (TextView) findViewById(R.id.tv1);
        tv2 = (TextView) findViewById(R.id.tv2);
        tv3 = (TextView) findViewById(R.id.tv3);
        tv4 = (TextView) findViewById(R.id.tv4);
        tv5 = (TextView) findViewById(R.id.tv5);
        tv6 = (TextView) findViewById(R.id.tv6);
        tv7 = (TextView) findViewById(R.id.tv7);
        tv8 = (TextView) findViewById(R.id.tv8);
        tvStart = (TextView) findViewById(R.id.tvStart);
        tvNotice = (TextView) findViewById(R.id.tv_notice);
        views.add(tv1);
        views.add(tv2);
        views.add(tv3);
        views.add(tv4);
        views.add(tv5);
        views.add(tv6);
        views.add(tv7);
        views.add(tv8);

        try {
            tvStart.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    tvStart.setClickable(false);
                    tvStart.setEnabled(false);
                    tvNotice.setText("");
                    runCount = 10;
                    timeC = 100;
                    views.get(lunckyPosition).setBackgroundColor(Color.TRANSPARENT);
                    lunckyPosition = randomNum(0,7);
                    new TimeCount(timeC*9,timeC).start();

                }
            });
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    /**
     * 生成随机数
     * @param minNum
     * @param maxNum
     * @return
     */
    private int randomNum(int minNum,int maxNum) {
        int max = maxNum;
        int min = minNum;
        Random random = new Random();
        return random.nextInt(max)%(max-min+1) + min;
    }

    class TimeCount extends CountDownTimer{
        public TimeCount(long millisInFuture, long countDownInterval) {
            super(millisInFuture, countDownInterval);
            lightPosition = 0;
        }

        @Override
        public void onTick(long millisUntilFinished) {

            Log.i(">>>","---"+lightPosition);
            //如果是最后一次滚动
            if (runCount>0){
                if (lightPosition>0){
                    views.get(lightPosition-1).setBackgroundColor(Color.TRANSPARENT);
                }
                if (lightPosition<8){
                    views.get(lightPosition).setBackgroundColor(Color.RED);
                }

            }else if (runCount==0){

                if (lightPosition<=lunckyPosition){
                    if (lightPosition>0){
                        views.get(lightPosition-1).setBackgroundColor(Color.TRANSPARENT);
                    }
                    if (lightPosition<8){
                        views.get(lightPosition).setBackgroundColor(Color.RED);
                    }
                }
            }

            lightPosition++;
        }
        @Override
        public void onFinish() {
            Log.i(">>>","onFinish=="+runCount);
            //如果不是最后一圈,需要还原最后一块的颜色
            TextView tvLast= views.get(7);
            if (runCount!=0){
                tvLast.setBackgroundColor(Color.TRANSPARENT);
                //最后几转速度变慢
                if (runCount<3) timeC += 200;
                new TimeCount(timeC*9,timeC).start();
                runCount--;
            }
            //如果是最后一圈且计时也已经结束
            if (runCount==0&&lightPosition==8){
                tvStart.setClickable(true);
                tvStart.setEnabled(true);
                tvNotice.setText("恭喜你抽中: "+views.get(lunckyPosition).getText().toString());
                if (lunckyPosition!=views.size())
                    tvLast.setBackgroundColor(Color.TRANSPARENT);

            }

        }
    }

}
<?xml version="1.0" encoding="utf-8"?>
<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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="cq.cake.luckdraw.MainActivity">
    <LinearLayout
        android:id="@+id/layout1"
        android:layout_above="@+id/layout2"
        android:layout_width="match_parent"
        android:layout_height="100dp">
        <TextView
            android:text="奖品1"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv1"/>
        <TextView
            android:text="奖品2"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv2"/>
        <TextView
            android:text="奖品3"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv3"/>

    </LinearLayout>
    <LinearLayout
        android:id="@+id/layout2"
        android:layout_centerInParent="true"
        android:layout_width="match_parent"
        android:layout_height="100dp">
        <TextView
            android:text="奖品8"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv8"/>
        <TextView
            android:textSize="20sp"
            android:text="开始抽奖"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tvStart"/>
        <TextView
            android:text="奖品4"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv4"/>
    </LinearLayout>
    <LinearLayout
        android:id="@+id/layout3"
        android:layout_below="@+id/layout2"
        android:layout_width="match_parent"
        android:layout_height="100dp">
        <TextView
            android:text="奖品7"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv7"/>
        <TextView
            android:text="奖品6"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv6"/>
        <TextView
            android:text="奖品5"
            style="@style/TextViewLuckDraw"
            android:id="@+id/tv5"/>

    </LinearLayout>

    <TextView
        android:layout_marginTop="16dp"
        android:textSize="20sp"
        android:gravity="center"
        android:textColor="@color/colorAccent"
        android:layout_below="@+id/layout3"
        android:id="@+id/tv_notice"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

</RelativeLayout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android打造流畅九宫格抽奖活动效果

    因为company项目中需要做九宫格抽奖活动,以前都没有做过类似的功能,虽然之前在浏览大神们的博客中,无意中也看到了好多关于抽奖的项目,但因为项目中没有需要,一直都没有点击进去看.这次不去看估计不行.直到公司计划要做抽奖功能,才迫不得已上网查找demo 网上找了大半天,好不容易找到了几个demo,下载下来,解压缩包发现竟然里面空空如也,只有几张九宫格的图片,害我白白浪费了几个CSDN积分.后面在eoe网站那发现了一个demo,于是好开心,下载下来后马上导入到工程中,运行看了效果,九宫格是出来了,

  • Android 实现九宫格抽奖功能

    效果展示 实现步骤 1.生成抽奖矩形: 其中每个矩形的宽高相同,长度为整个控件宽度的1/3. 代码展示 public class NineLuckPan extends View { private Paint mPaint; private ArrayList<RectF> mRects;//存储矩形的集合 private float mStrokWidth = 5;//矩形的描边宽度 private int mRectSize;//矩形的宽和高(矩形为正方形) private int[]

  • Android自定义View实现QQ运动积分转盘抽奖功能

    因为偶尔关注QQ运动, 看到QQ运动的积分抽奖界面比较有意思,所以就尝试用自定义View实现了下,原本想通过开发者选项查看下界面的一些信息,后来发现积分抽奖界面是在WebView中展示的,应该是在H5页面中用js代码实现的,暂时不去管它了. 这里的自定义View针对的是继承自View的情况,你可以将Canvas想象为画板, Paint为画笔,自定义View的过程和在画板上用画笔作画其实类似,想象在画板上作画的过程,你要画一个多大图形(对应View的测量 onMeasure方法),你要画什么样的图

  • Android使用surfaceView自定义抽奖大转盘

    使用surfaceView自定义抽奖大转盘 话不多说,先上效果图 完整代码地址欢迎start 实现思路以及过程 1.首先了解SurfaceView的基本用法,它跟一般的View不太一样,采用的双缓存机制,可以在子线程中绘制View,不会因为绘制耗时而失去流畅性,这也是选择使用SurfaceView去自定义这个抽奖大转盘的原因,毕竟绘制这个转盘的盘块,奖项的图片和文字以及转动都是靠绘制出来的,是一个比较耗时的绘制过程. 2.使用SurfaceView的一般模板样式 一般会用到的成员变量 priva

  • Android中利用SurfaceView制作抽奖转盘的全流程攻略

    一.概述 今天给大家带来SurfaceView的一个实战案例,话说自定义View也是各种写,一直没有写过SurfaceView,这个玩意是什么东西?什么时候用比较好呢? 可以看到SurfaceView也是继承了View,但是我们并不需要去实现它的draw方法来绘制自己,为什么呢? 因为它和View有一个很大的区别,View在UI线程去更新自己:而SurfaceView则在一个子线程中去更新自己:这也显示出了它的优势,当制作游戏等需要不断刷新View时,因为是在子线程,避免了对UI线程的阻塞. 知

  • Android App中实现简单的刮刮卡抽奖效果的实例详解

    主要思想: 将一个view设计成多层:背景层,含中奖信息等: 遮盖层,用于刮奖,使用关联一个Bitmap的Canvas 在该Bitmap上,使用它的canvas.drawPath的api来处理 手势滑动(类似刮奖的动作) 使用paint.setXfermode 来进行消除手势滑动区域 public class GuaView extends View { private Bitmap mBitmap; //遮盖的图层 private Canvas mCanvas; //绘制遮盖图层 privat

  • Android自定义View实现抽奖转盘

    本文实例为大家分享了Android自定义View实现抽奖转盘的具体代码,供大家参考,具体内容如下 public class LuckCircle extends SurfaceView implements SurfaceHolder.Callback,Runnable { private SurfaceHolder mHolder; private Canvas mCanvas; //用于绘制的线程 private Thread mThread; //线程开关的控制 private boole

  • Android抽奖轮盘的制作方法

    本文实例为大家分享了Android抽奖轮盘的具体代码,供大家参考,具体内容如下 main布局(图片资源请自行寻找,抱歉) <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_gra

  • 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; im

  • Android简单实现圆盘抽奖界面

    闲来无事,做了一个简单的抽奖转盘的ui实现,供大家参考 package com.microchange.lucky; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.RectF; import android.util.AttributeSet;

随机推荐