#小程序云开发挑战赛#--东方小游戏-一枝花
发布于 4 年前 作者 weishen 5243 次浏览 来自 分享

应用场景: 微信小程序内,游戏娱乐,玩家交流使用

目标用户:娱乐用户

实现思路:多个网页实现流程交互,使用云存储功能存储图片和玩家留言板消息。使用js实现页面音乐播放,音乐源来自QQ音乐。

效果截图:

功能代码展示:

首页

<view class="container">

<navigator bindtap="innerchatroom" id="chatroom" url="../im/room/room" open-type="navigate" class="uploader-text">

      <text>评论留言版</text>

  </navigator>

<view id="atfirst"></view>

<button id="toplay" bindtap="changewebtoplay">点击开始</button>

</view>


js部分:

onLoad: function() {

    if (!wx.cloud) {

      wx.redirectTo({

        url: '../chooseLib/chooseLib',

      })

      return

    }

    innerAudioContext.autoplay = false

    innerAudioContext.src = '?'

    innerAudioContext.onPlay(() => {

      console.log('开始播放')

    })

    innerAudioContext.play()

    innerAudioContext.onError((res) => {

      console.log(res.errMsg)

      console.log(res.errCode)

    })

    wx.getSetting({

      success: res => {

        if (res.authSetting['scope.userInfo']) {

          wx.getUserInfo({

            success: res => {

              this.setData({

                avatarUrl: res.userInfo.avatarUrl,

                userInfo: res.userInfo

              })

            }

          })

        }

      }

    })

  },

  onGetUserInfo: function(e) {

    if (!this.data.logged && e.detail.userInfo) {

      this.setData({

        logged: true,

        avatarUrl: e.detail.userInfo.avatarUrl,

        userInfo: e.detail.userInfo

      })

    }

  },

  changewebtoplay:function(){

      // wx.stopVoice();

      wx.redirectTo({

        url: '../question/question1',

      })

      innerAudioContext.stop()

  },

  innerchatroom:function(){

    innerAudioContext.stop()

  },

单个问题界面

<view id="backgroundscenery">

  <view id="questionbox">

  <text>欢迎你,初入幻想之人</text>

  <text>随着旅行团旅游的你和大伙走散了,你只身来到一所未知的神庙,在此触碰到幻想的境界,你将成为幻想乡中的一员,现在来选择你的种族吧:</text>

  </view>

  <text class="anws {{animated1?'':'becheck'}}" bindtap="checked1" >妖精</text>

  <text class="anws {{animated2?'':'becheck'}}" bindtap="checked2">人类</text>

  <text class="anws {{animated3?'':'becheck'}}" bindtap="checked3">妖怪</text>

</view>

js部分:

checked1:function(options){

    this.setData({

      animated1:false

    })

    setTimeout(function(){

      wx.redirectTo({

        url: '../question2/question2',

      })

    },2000)

  },

  checked2:function(options){

    this.setData({

      animated2:false

    })

    setTimeout(function(){

      wx.redirectTo({

        url: '../question5/question5',

      })

    },2000)

  },

  checked3:function(options){

    this.setData({

      animated3:false

    })

    setTimeout(function(){

      wx.redirectTo({

        url: '../question5/question5',

      })

    },2000)

  },

  data: {

      animated1:true,

      animated2:true,

      animated3:true

  },

人物卡片界面

    <view id=“talkbox1” style=“position:fixed;z-index:999;color:#ff7675;font-size:1.5rem”>你遇见了:雾雨魔理沙</view>

    <image bindtap=“checked2” mode=“scaleToFill” class=“backgroundscenery” src=“cloud://xly-ugom6.786c-xly-ugom6-1302909523/魔理沙.jpg”><view class=“uploader”> </view></image>

    <navigator style=“z-index:999” url="…/im/room/room" open-type=“navigate” class=“uploader-text”><image style=“top:0.5rem;right:1rem;z-index:999;position:fixed;height:50px;width:50px” src=“cloud://xly-ugom6.786c-xly-ugom6-1302909523/聊天.png”></image>

    </navigator>

    <view id=“talkbox2” class="{{animated?’’:‘anima1’}}" >

    <text style=“display:block;font-size:1.5rem;color:orange”>雾雨魔理沙:</text>

    <text style=“font-size:1.2rem;color:#fdcb6e;text-indent:2rem”>虽然这本书原本是属于你的啦,但至于为什么现在在我手上,这…这本书可不是我偷的哦,魔法师的事情怎么能叫偷呢?</text>

    </view>

    <image bindtap=“checked1” style=“bottom:0.5rem;right:1rem;z-index:999;position:fixed;height:50px;width:50px;” src=“cloud://xly-ugom6.786c-xly-ugom6-1302909523/下一步.png”></image>

    <text style=“top:calc(.5rem + 50px);;right:1rem;z-index:999;position:fixed;height:50px;width:50px;font-size:.5rem;color:#e55039;” >评论留言</text>

    js部分:

    checked1:function(options){

    wx.redirectTo({

      url: ‘…/question8/question8’,

    })

  },

  checked2:function(options){

    this.setData({

      animated:false

    })

  },

  data: {

    animated:true,

  },

  onLoad: function (options) {

    innerAudioContext.autoplay = true

    innerAudioContext.src = ‘?’

    innerAudioContext.onPlay(() => {

      console.log(‘开始播放’)

    })

    innerAudioContext.onError((res) => {

      console.log(res.errMsg)

      console.log(res.errCode)

    })

  },

留言板部分

<view class=“container”>

  <view class=“uploader”>

    <navigator url="./room/room" open-type=“navigate” class=“uploader-text”>

      <text>留言板</text>

    </navigator>

  </view>

</view>

js部分:

data: {

    avatarUrl: ‘./user-unlogin.png’,

    userInfo: null,

    logged: false,

    takeSession: false,

    requestResult: ‘’,

    chatRoomCollection: ‘chatroom’,

    chatRoomGroupId: ‘demo’,

    chatRoomGroupName: ‘幻想留言板’,

    onGetUserInfo: null,

    getOpenID: null,

  },

  onLoad: function() {

    wx.getSetting({

      success: res => {

        if (res.authSetting[‘scope.userInfo’]) {

          wx.getUserInfo({

            success: res => {

              this.setData({

                avatarUrl: res.userInfo.avatarUrl,

                userInfo: res.userInfo

              })

            }

          })

        }

      }

    })

    this.setData({

      onGetUserInfo: this.onGetUserInfo,

      getOpenID: this.getOpenID,

    })

    wx.getSystemInfo({

      success: res => {

        console.log(‘system info’, res)

        if (res.safeArea) {

          const { top, bottom } = res.safeArea

          this.setData({

            containerStyle: `padding-top: ${(/ios/i.test(res.system) ? 10 : 20) + top}px; padding-bottom: ${20 + res.windowHeight - bottom}px`,

          })

        }

      },

    })

  },

  getOpenID: async function() {

    if (this.openid) {

      return this.openid

    }

    const { result } = await wx.cloud.callFunction({

      name: ‘login’,

    })

    return result.openid

  },

  onGetUserInfo: function(e) {

    if (!this.logged && e.detail.userInfo) {

      this.setData({

        logged: true,

        avatarUrl: e.detail.userInfo.avatarUrl,

        userInfo: e.detail.userInfo

      })

    }

  },

  onShareAppMessage() {

    return {

      title: ‘幻想聊天室’,

      path: ‘/pages/im/room/room’,

    }

  },

})

团队简介:

李君豪(天津城建大学 电信工程系) 负责”菜“,前端,后端

10 回复

棒棒的

期待更好的作品问世。

👍👍👍👍👍

挺棒的!继续努力哦

好期待的小游戏!

把学到东西运用到创作中,好啊!

回到顶部