掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

时间:2024-08-15 22:35:32

---恢复内容开始---

今天我们来讲的就是项目《掷骰子》

首先我们先下载资源包,也就是我们需要的图片【点击图片下载】

    在我们下载完图片之后,我们就可以开始创建项目

一、我们项目的做法可以有两种:

   掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)               掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

首先我们要看一下我们需要看一下我们的要求成果图

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

我们创建一个新项目,定义一个throwsDice名字,使用swift语言

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

创建完之后我们就会看到上面这个图:

   我们需要关注ViewController和Main

      1、ViewController就是一个视图控制器

       2、Main就是我们的视图

  1. 首先我们先把界面画好

在放骰子的地方需要三张图片,那么我们需要在属性那里找到imageview,

调整imageview的大小,再复制粘贴出2份,就成了下图所示

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)             掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

接下来就是点击按钮,买大买小豹子,

    如下图找到button,拖拽到界面上,调整位置和大小,复制出两份,双击按钮写按钮作用,如下图

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)      掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

最后就是关于显示买家和庄家的钱数

      我们使用label,,调整位置和大小,复制粘贴多份,双击命名,填写初始值

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)        掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

现在我们的界面就做好了

如何将图片放在imageview上呢?

将我们下载的图片压缩包解压之后,拖入项目中,我们一般是放在Assets.xcassets的一个文件夹中,这里我为了快速,就直接放在外面了

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

之后点击对应的imageview,点击右上角的属性,找到图片这一行没选择自己在界面上第一次显示的图片(初始化图片)

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)        掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

然后效果就是这样的了!

    2.将视图和视图控制器关联起来

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

    3.将功能实现(1、图片切换   2、按钮买大买小   3、判断输赢进行加减运算)

            我们的功能在Viewcontroller中进行

如何进行绑定呢?

  点击Main,再点击右上角两个圈圈的图案就会显示如图

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

点击你要绑定的imageview或者button或者label

右键直接拉到视图控制器这个类中,一般的选outlet   事件选action。注意:在这里没有*类

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

这个是按钮的绑定事件,第一个按钮是买大,第二个是卖豹子,第三个是买小

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

切换图片,就是上图中我们调用的changeImage方法,所以我们要自定义一个方法来切换

    在图中使用的imageNumber我们在方法外就要定义赋初始值  var imageNumber = 0  和 我们使用的timer初始化 var timer:Timer?

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

如何判断是买大买小,我们使用枚举来区别:在类外设置一个枚举,在类中初始化var selectType = SelectType.Big,这样就可以调用枚举进行判断你点击的是买大还是买小

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

判断输赢给买家和庄家进行加减,当然图中使用的一些属性需要定义

var dice1Num:Int = 0

var dice2Num:Int = 0

var dice3Num:Int = 0

var playerMoney = 1000

var bossMoney = 1000

掷骰子-IOS新手项目练习(抱歉,由于个人原因,图片没显示,要源码的项目私聊)

于是我们这个简单的掷骰子就基本完成了,当然如果我们让它可以横屏同样玩,则需要加约束

下面就是控制器中所有的代码

 //
// ViewController.swift
// throwsDice
//
// Created by c03 on 2016/11/25.
// Copyright © 2016年 MakeSmallApp. All rights reserved.
// import UIKit
//定义一个枚举
enum SelectType{
case Big,Same,Small
}
class ViewController: UIViewController { @IBOutlet weak var playLabel: UILabel! @IBOutlet weak var bossLabel: UILabel! @IBOutlet weak var diceViewOne: UIImageView!
@IBOutlet weak var diceViewTwo: UIImageView!
@IBOutlet weak var diceViewThree: UIImageView! var selectType = SelectType.Big
var dice1Num:Int =
var dice2Num:Int =
var dice3Num:Int =
var playerMoney =
var bossMoney = //判断输赢
func judgeResult(){
let zhongjian = dice1Num + dice2Num
let sum = zhongjian + dice3Num
switch selectType {
case .Big:
if sum > {
self.playerMoney+=
self.bossMoney-=
}else{
self.playerMoney-=
self.bossMoney+=
}
case .Same:
if dice1Num == dice2Num && dice2Num == dice3Num {
self.playerMoney+=
self.bossMoney-=
}else{
self.playerMoney-=
self.bossMoney+=
}
case .Small:
if sum < {
self.playerMoney+=
self.bossMoney-=
}else{
self.playerMoney-=
self.bossMoney+=
} default:
print("这是默认的")
}
playLabel.text = String(playerMoney)
bossLabel.text = String(bossMoney) } func changeImage(){
let i1 = arc4random()% +
let name1 = String(i1) + ".gif"
let image1 = UIImage(named: name1)
diceViewOne.image = image1
dice1Num = Int(i1) let i2 = arc4random()% +
let name2 = String(i2) + ".gif"
let image2 = UIImage(named: name2)
diceViewTwo.image = image2
dice2Num = Int(i2) let i3 = arc4random()% +
let name3 = String(i3) + ".gif"
let image3 = UIImage(named: name3)
diceViewThree.image = image3
dice3Num = Int(i3) imageNumber +=
if imageNumber > {
timer?.invalidate()
imageNumber =
judgeResult()
}
}
var timer:Timer?
var imageNumber = @IBAction func btnOne(_ sender: Any) {
selectType = .Big
//定义一个定时器来控制换图片
timer?.invalidate()
timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(ViewController.changeImage), userInfo: nil, repeats: true)
}
@IBAction func btnTwo(_ sender: Any) {
selectType = .Same
//定义一个定时器来控制换图片
timer?.invalidate()
timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(ViewController.changeImage), userInfo: nil, repeats: true)
}
@IBAction func btnThree(_ sender: Any) {
selectType = .Small
//定义一个定时器来控制换图片
timer?.invalidate()
timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(ViewController.changeImage), userInfo: nil, repeats: true)
} override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
} }

大家可以试试,写个博客半天就没了,时间过的好快,吃饭去了!Bye