小程序扎金花游戏开发教程全面解读

why 121 2024-10-21 10:59:58

微信小程序  扎金花

实现效果图:

image.png

image.png

app.json:

1

2

3

4

5

6

7

8

9

10

11

{

    "pages": ["pages/index/index"],

    "window": {

        "navigationBarBackgroundColor": "#333333",

        "navigationBarTextStyle": "white",

        "navigationBarTitleText": "炸金花",

        "backgroundColor": "#ffffff",

        "backgroundTextStyle": "light",

        "enablePullDownRefresh": false

    }

}

  index.js:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

Page({

    data: {

        num1: 1,

        num2: 2,

        num3: 3,

        imgNum1: 1,

        imgNum2: 2,

        imgNum3: 3,

        b1: "white",

        b2: "white",

        b3: "white",

        flag: true,

        butype: "primary",

        butext: "开始",

        hidden: true,

        score: 0

    },

    start: function() {

        var that = this;

        that.setData({

            butype: "default",

            butext: "停止"

        }) if (this.data.flag) {

            this.go = setInterval(function() {

                that.setData({

                    num1: Math.ceil(Math.random() * 10),

                    num2: Math.ceil(Math.random() * 10),

                    num3: Math.ceil(Math.random() * 10),

                    imgNum1: Math.ceil(Math.random() * 4),

                    imgNum2: Math.ceil(Math.random() * 4),

                    imgNum3: Math.ceil(Math.random() * 4),

                    b1: "#" + Math.floor(Math.random() * 1000000),

                    b2: "#" + Math.floor(Math.random() * 1000000),

                    b3: "#" + Math.floor(Math.random() * 1000000)

                })

            },

            100) this.setData({

                flag: false,

                hidden: true,

                score: 0

            })

        } else {

            clearInterval(this.go) this.setData({

                flag: true,

                butype: "primary",

                butext: "开始",

                b1: "white",

                b2: "white",

                b3: "white"

            }) var n1 = this.data.num1;

            var n2 = this.data.num2;

            var n3 = this.data.num3;

            var img1 = this.data.imgNum1;

            var img2 = this.data.imgNum2;

            var img3 = this.data.imgNum3;

            var result = n1 + n2 + n3;

            if (img1 == img2 && img2 == img3) {

                result += 20;

            } else if (img1 == img2 || img2 == img3 || img1 == img3) {

                result += 10;

            }

            var newarr = new Array();

            newarr.push(n1) newarr.push(n2) newarr.push(n3) for (var i = 0; i < newarr.length; i++) {

                for (var j = i + 1; j < newarr.length; j++) {

                    if (newarr > newarr[j]) {

                        var tmp = newarr;

                        newarr = newarr[j];

                        newarr[j] = tmp;

                    }

                }

            }

            if (((newarr[2] - newarr[1]) == 1) && ((newarr[1] - newarr[0]) == 1)) {

                result += 30;

            } else if (newarr[2] == newarr[1] || newarr[2] == newarr[0] || newarr[0] == newarr[1]) {

                result += 10;

            } else if (newarr[2] == newarr[1] && newarr[2] == newarr[0]) {

                result += 40;

            }

            this.setData({

                hidden: false,

                score: result

            })

        }

    },

    onShareAppMessage: function() {

        return {

            title: "大小之争",

            desc: &#39;激烈的竞技游戏&#39;,

            path: &#39;/pages/index/index&#39;

        }

    }

})

  index.wxml:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

<html>

 <head></head>

 <body>

  <view style="text-align:center;position:fixed;top:10px;left:0;width:100%;color:green;font-weight:bolder" hidden="pw_hidden">

   恭喜你得了pw_score分!

  </view>

  <view style="clear:both;overflow:hidden;display:flex;margin-top:50px">

   <view class="container" style="background:pw_b1;">

    <text class="text">

     pw_num1

    </text>

    <img  class="img" src="../../images/pw_imgNum1.png"   style="max-width:90%" / alt="小程序游戏开发之扎金花" >

    <text class="text1">

     pw_num1

    </text>

   </view>

   <view class="container" style="background:pw_b2;">

    <text class="text">

     pw_num2

    </text>

    <img  class="img" src="../../images/pw_imgNum2.png"   style="max-width:90%" / alt="小程序游戏开发之扎金花" >

    <text class="text1">

     pw_num2

    </text>

   </view>

   <view class="container" style="background:pw_b3;">

    <text class="text">

     pw_num3

    </text>

    <img  class="img" src="../../images/pw_imgNum3.png"   style="max-width:90%" / alt="小程序游戏开发之扎金花" >

    <text class="text1">

     pw_num3

    </text>

   </view>

  </view>

  <button bindtap="start" type="pw_butype" style="margin:20px">pw_butext</button>

  <view style="font-size:13px;padding:20px;color:gray">

   <view>

    1.如果三张数字相同得40分,如果三张数字是连续的得30分,如果两个数字是相同的得10分

   </view>

   <view>

    2.如果三张花色一样得20分,如果两张花色一样得10分

   </view>

   <view>

    3.三张数字之和

   </view>

   <view>

    以上所有数字的总和为总分

   </view>

  </view>

 </body>

</html>

  index.wxss:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

.container {

width: 30%;

height: 200px;

position: relative;

border: 1px solid #787775;

box-sizing: border-box;

display: inline-block;

flex: 1;

margin: 10px;

border-radius: 10px;

box-shadow: 5px 5px 3px #787775

}

.text {

width: 30px;

height: 30px;

position: absolute;

top: 15px;

left: 15px;

font-size: 25px;

font-weight: bolder

}

.img {

width: 50px;

height: 50px;

position: absolute;

top: 50%;

left: 50%;

margin-left: -25px;

margin-top: -25px

}

.text1 {

width: 30px;

height: 30px;

position: absolute;

bottom: 15px;

right: 15px;

font-size: 25px;

font-weight: bolder;

transform: rotate(180deg)

}

 1.png:

image.png

2.png:

image.png

3.png

image.png

4.png

image.png

以上就是小程序游戏开发之扎金花的详细内容。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信公众号平台开发视频教程详细解析
下一篇:小程序开发解析网页内容教程深度剖析
相关文章