Android实现掷骰子效果

本文实例为大家分享了Android实现掷骰子效果的具体代码,供大家参考,具体内容如下

利用handler接受子线程的消息完成骰子点数的不断更替

演示

START:开始游戏
STOP:停止游戏
RECOVER:重置色子到初始状态

代码

package com.example.homeworkten;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
 private ImageView imageView1,imageView2,imageView3;
 private Button button1,button2,button3;
 private ImageView[] imageViews;
 private Handler handler;
 //子线程
 private Thread thread;
 //记录每个色子的点数
 private int number[];
 //色子的总点数
 private int count;
 //volatile修饰符用来保证其它线程读取的总是该变量的最新的值
 public volatile boolean isStop = false;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 number = new int[3];
 imageView1 = findViewById(R.id.imageView1);
 imageView2 = findViewById(R.id.imageView2);
 imageView3 = findViewById(R.id.imageView3);
 button1 = findViewById(R.id.button1);
 button2 = findViewById(R.id.button2);
 button3 = findViewById(R.id.button3);
 imageViews = new ImageView[]{imageView1,imageView2,imageView3};
 button1.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  //判断线程是否存在
  if (thread != null&&isStop == true){
   isStop = false;
  }
  handler = new Handler(){
   @Override
   public void handleMessage(@NonNull Message msg) {
   super.handleMessage(msg);
   for(int i = 0;i < 3;i++) {
    switch (number[i]) {
    case 1:
     imageViews[i].setImageResource(R.drawable.t1);
     break;
    case 2:
     imageViews[i].setImageResource(R.drawable.t2);
     break;
    case 3:
     imageViews[i].setImageResource(R.drawable.t3);
     break;
    case 4:
     imageViews[i].setImageResource(R.drawable.t4);
     break;
    case 5:
     imageViews[i].setImageResource(R.drawable.t5);
     break;
    case 6:
     imageViews[i].setImageResource(R.drawable.t6);
     break;
    }
   }
   }
  };
  thread = new Thread(new Runnable() {
   @Override
   public void run() {
   while (!isStop) {
    Message message = handler.obtainMessage();
    //总点数归零
    count = 0;
    for (int i = 0; i < 3; i++) {
    try {
     Thread.sleep(50);
    } catch (InterruptedException e) {
     e.printStackTrace();
    }
    //生成随机数
    int random = (int) (Math.random() * 6 + 1);
    number[i] = random;
    count += random;
    }
    handler.sendMessage(message);
   }
   }
  });
  thread.start();
  }
 });
 //停止掷筛子
 button2.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  if(isStop == false) {
   isStop = true;
   try {
   //当子线程执行完以后才继续执行主线程
   thread.join();
   } catch (InterruptedException e) {
   e.printStackTrace();
   }
   //显示掷出的点数
   Toast.makeText(MainActivity.this, "你掷的点数为" + count, Toast.LENGTH_SHORT).show();
  }else {
   Toast.makeText(MainActivity.this, "请点击开始键进行掷色子", Toast.LENGTH_SHORT).show();
  }
  }
 });
 //将色子还原到初始状态
 button3.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  if(isStop == true) {
   for (int i = 0; i < 3; i++) {
   imageViews[i].setImageResource(R.drawable.t1);
   }
  }else {
   Toast.makeText(MainActivity.this, "请先停止游戏,再重新开始", Toast.LENGTH_SHORT).show();
  }
  }
 });
 }
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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:layout_width="match_parent"
 android:layout_height="match_parent"
 tools:context=".MainActivity">

 <ImageView
 android:id="@+id/imageView1"
 android:layout_width="100dp"
 android:layout_height="80dp"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 app:layout_constraintEnd_toStartOf="@+id/imageView2"
 app:layout_constraintHorizontal_bias="0.482"
 app:layout_constraintStart_toStartOf="parent"
 app:layout_constraintTop_toTopOf="parent"
 app:srcCompat="@drawable/t1" />

 <ImageView
 android:id="@+id/imageView2"
 android:layout_width="100dp"
 android:layout_height="80dp"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 app:layout_constraintEnd_toStartOf="@+id/imageView3"
 app:layout_constraintStart_toEndOf="@+id/imageView1"
 app:layout_constraintTop_toTopOf="parent"
 app:srcCompat="@drawable/t1" />

 <Button
 android:id="@+id/button1"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 android:text="start"
 app:layout_constraintEnd_toStartOf="@+id/button2"
 app:layout_constraintStart_toStartOf="parent"
 app:layout_constraintTop_toBottomOf="@+id/imageView1" />

 <Button
 android:id="@+id/button2"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 android:text="stop"
 app:layout_constraintEnd_toStartOf="@+id/button3"
 app:layout_constraintStart_toEndOf="@+id/button1"
 app:layout_constraintTop_toBottomOf="@+id/imageView2" />

 <Button
 android:id="@+id/button3"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 android:text="recover"
 app:layout_constraintEnd_toEndOf="parent"
 app:layout_constraintStart_toEndOf="@+id/button2"
 app:layout_constraintTop_toBottomOf="@+id/imageView3" />

 <ImageView
 android:id="@+id/imageView3"
 android:layout_width="100dp"
 android:layout_height="80dp"
 android:layout_marginStart="10dp"
 android:layout_marginLeft="10dp"
 android:layout_marginTop="40dp"
 android:layout_marginEnd="10dp"
 android:layout_marginRight="10dp"
 app:layout_constraintEnd_toEndOf="parent"
 app:layout_constraintStart_toEndOf="@+id/imageView2"
 app:layout_constraintTop_toTopOf="parent"
 app:srcCompat="@drawable/t1" />

</androidx.constraintlayout.widget.ConstraintLayout>

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

(0)

相关推荐

  • Android实现微信摇骰子游戏

    过年怎么可以不玩红包娱乐一下呢,微信里的摇骰子大小和石头剪刀布就是不错的游戏方式. 使用Java的Random函数很容易实现,以骰子为例: 1.骰子摇动的动画,使用animation-list帧动画实现 2.生成1~6的随机数,1 + new Random().nextInt(6) 以下是代码实现,文末提供图片资源下载: package com.zms.dicedemo; import java.util.Random; import android.app.Activity; import a

  • Android 微信摇骰子和猜拳作弊器原理解析

    一.前言 在之前的一篇文章中我们已经详细介绍了Android中Hook工作的一款神器Xposed工具:Xposed框架原理解析和使用案例分析 在那一篇文章中我们介绍了如何安装Xposed框架,以及如何使用Xposed库编写第一个模块来做到修改系统方法功能的效果,同时也说到了一个非常重要的知识点就是:在Hook过程中最重要的一点就是如何找到Hook点,而对于这一点很多同学都会感觉到非常的困难,因为对于修改系统方法还好,因为可以简单的去查看具体的Android源码即可,但是如果说要去编写一些应用和游

  • Android实现掷骰子效果

    本文实例为大家分享了Android实现掷骰子效果的具体代码,供大家参考,具体内容如下 利用handler接受子线程的消息完成骰子点数的不断更替 演示 START:开始游戏 STOP:停止游戏 RECOVER:重置色子到初始状态 代码 package com.example.homeworkten; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import android.

  • js实现简单掷骰子效果

    本案例要实现的掷骰子效果: 点击按钮,使骰子转动起来,转动随机时间之后,自动停止在某一个点数上. 思路: 点击按钮之后,将原本静态的骰子图片替换为一个动态转动的gif图片: 创建定时器,实现随机时间之后,动态的图片随机替换为1~6点图片的任意一张图片. 注意: 1.要考虑用户点击一次按钮后再连续多次点击按钮的情况. 2.为了防止不必要的问题,需要设置使定时器执行完毕一次之后,再点击按钮才有效. 3.这里设置了一个开关: 用户点击按钮时,先判断开关是否关闭,如未关闭,可执行函数内容: 若开关已关闭

  • Java编写掷骰子游戏

    废话不多说了,直接奔主题. **多线程&&观察者模式 题目要求:<掷骰子>窗体小游戏,在该游戏中,玩家初始拥有1000的金钱,每次输入押大还是押小,以及下注金额,随机3个骰子的点数,如果3个骰子的总点数小于等于9,则开小,否则开大,然后判断玩家是否押对,如果未押对则扣除下注金额,如果押对则奖励和玩家下注金额相同的金钱. 分析:这个题目要求灵活运用多线程的相关知识,达到点击开始按钮时,有3个线程启动,分别控制3颗骰子的转动,在3颗骰子全部转完以后,回到主线程计算游戏结果. //个

  • Pycharm中安装Pygal并使用Pygal模拟掷骰子(推荐)

    使用Python可视化Pygal包来生成可缩放的矢量图形文件! 对于在尺寸不同的屏幕上显示图标,它们将自动缩放以适合观看者的屏幕,如果以在线的方式使用图标,建议使用Pygal来生成,这样在任何设备上显示都会很美观!!! 1.安装Pygal 安装Pygal有好几种办法这边简略带过!!! 介绍一种在pycharm中直接安装的方法! 1.在File文件中打开Settings 2.找到Project:untitled打开Projiect lnterpreter右上方的+号 3.输入我们要安装的Pygal

  • C语言模拟掷骰子游戏

    目录 实现掷骰子小游戏 实现原理 源码介绍 效果展示 今日练习 题目描述 问题分析 代码实现 运行结果 实现掷骰子小游戏 在开始今天的练习前,我先写一个有趣的C语言小游戏--掷骰子(zhì tóu zi) 实现原理 大家对骰子应该不陌生,让我们先看看百度词条的介绍: 掷骰子 拼音:zhì tóu zi 骰子: 既色子,用象牙.骨头或塑料等较坚硬物体做的小四方块:每面刻有点数,一到六,常用一对做各种游戏或赌博. 掷骰子:先摇动骰子,然后抛掷使两个骰子都随意停止在一平面上. --百度百科 掷骰子时,

  • php实现的中秋博饼游戏之掷骰子并输出结果功能详解

    本文实例讲述了php实现的中秋博饼游戏之掷骰子并输出结果功能.分享给大家供大家参考,具体如下: 前面讲述了php实现的中秋博饼游戏之绘制骰子图案功能,纯php实现,就要用php来生成图案,第一步就先绘制骰子图案.下面就是编码实现业务逻辑,具体代码如下: <?php class roll { private $_defRank = 'lk'; public function lottery() { $dice = $this->rollDice(); $format = $this->fo

  • 分享Android仿刮奖效果控件

    本文实例为大家分享了Android刮刮卡效果控件,供大家参考,具体内容如下 刮刮卡类: package com.reyo.view; import android.content.Context; import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Paint; import android.gr

  • Android实现左右滑动效果的方法详解

    本示例演示在Android中实现图片左右滑动效果. 关于滑动效果,在Android中用得比较多,本示例实现的滑动效果是使用ViewFlipper来实现的,当然也可以使用其它的View来实现.接下来就让我们开始实现这种效果.为了方便大家理解,我们先来看一下效果图:主要效果图如下图:    接下来我们看一下程序结构图: MainActivity文件中代码: 复制代码 代码如下: package com.android.flip;import android.app.Activity;import a

  • Android编程ViewPager回弹效果实例分析

    本文实例讲述了Android编程ViewPager回弹效果.分享给大家供大家参考,具体如下: 其实在我们很多应用中都看到当ViewPager滑到第一页或者最后一页的时候,如果再滑动的时候,就会有一个缓冲的过程,也就是回弹效果.之前在研究回弹效果的时候,也顺便实现了ViewPager的回弹效果,其实也很简单,一下是实现代码,注释比较少: package com.freesonfish.viewpager_2; import android.content.Context; import andro

  • Android实现跑马灯效果的方法

    本文实例讲述了Android实现跑马灯效果的方法.分享给大家供大家参考.具体如下: 运行效果截图如下: 直接在布局里写代码就好了: <TextView android:id="@+id/menu_desc" android:layout_width="300dip" android:layout_height="wrap_content" android:text="温馨提示:左右滑动更改菜单,点击进入" android

随机推荐