uniapp+pixijs写的一个转盘

1,turntable.vue文件,这个里面显示菜单的时候,上一行文字还不能消除,我已经在研究了,等我搞好了我会更新这里的。后期等我多研究研究pixijs,我会出一些pixijs的文章。

<template>
    <view>
        <div id='pixi'></div>
    </view>
</template>

<script>
    export default {
        props: ['menu'],
        data() {
            return {
                app: null,
                container: null,
                winW: 0,
            }
        },
        mounted() {
            this.initPixi()
        },

        methods: {

            initPixi() {
                let type = "WebGL"
                if (!PIXI.utils.isWebGLSupported()) {
                    type = "canvas"
                }

                PIXI.utils.sayHello(type)
                this.app = new PIXI.Application({
                    width: 456, // default: 800
                    height: 456, // default: 600
                    antialias: true, // default: false
                    backgroundAlpha: false, // default: false
                    resolution: 1,
                })
                document.getElementById("pixi").appendChild(this.app.view);

                this.container = new PIXI.Container()
                this.app.stage.addChild(this.container)

                let sprite = PIXI.Sprite.from('/static/turnbg3.png');
                this.winW = document.body.clientWidth

                sprite.width = this.winW
                sprite.height = this.winW

                this.container.addChild(sprite);
                this.container.x = this.winW / 2;
                this.container.y = 250;
                this.container.pivot.x = this.container.width / 2
                this.container.pivot.y = this.container.width / 2

                let spritePointer = PIXI.Sprite.from('/static/pointer1.png');

                spritePointer.width = 75
                spritePointer.height = 100
                spritePointer.x = this.winW / 2 - 37
                spritePointer.y = 186

                this.app.stage.addChild(spritePointer);

            },
            rorate() {
                let angle = Math.floor(this.container.angle + Math.random() * 1000)

                let currentAngle = (angle - 45) % 360

                let index = 9 - (Math.floor(currentAngle / 45) == 0 ? 8 : Math.floor(currentAngle / 45))

                let singleAngle = (angle % 360)
                let toatlAngle = angle - (angle % 45) - 45 > 0 ? angle - (angle % 45) - 45 : 0

                // Listen for animate update

                console.log('index', index, angle, currentAngle, this.container.angle, toatlAngle)

                this.app.ticker.add((delta) => {
                    if (this.container.angle < toatlAngle) {
                        this.container.angle = this.container.angle >= toatlAngle ? toatlAngle : (this.container
                            .angle + 3 * delta)
                        // setTimeout(() => {
                        //     let msg = '今日菜单:'
                        //     if (index > this.menu.length) {
                        //         msg += '西北风'
                        //     } else {
                        //         msg += '' + this.menu[index - 1].dishName
                        //     }
                        //     this.currentMenu(msg)
                        // }, 30 * delta)
                    }
                });
                let msg = '今日菜单:'
                if (index > this.menu.length) {
                    msg += '西北风'
                } else {
                    msg += '' + this.menu[index - 1].dishName
                }
                setTimeout(() => {
                    this.currentMenu(msg)
                }, 4000)

            },
            currentMenu(msg) {
                console.log('this.app', this.app.stage.children)
                this.app.stage.children.clear()
                let menuTriangle = new PIXI.Graphics();
                menuTriangle.width = this.winW
                menuTriangle.height = this.winW
                menuTriangle.x = 10
                menuTriangle.y = 0
                let style = new PIXI.TextStyle({
                    fontFamily: 'Arial',
                    fontSize: 12,
                    fill: '#ff5400',
                    lineHeight: 40,
                    // wordWrapWidth: (265 / 3) * 2,
                    wordWrapWidth: this.win - 10,
                    wordWrap: true,
                    breakWords: true,
                });
                let currentMenu = new PIXI.Text(msg, style);
                currentMenu.x = 0 currentMenu.y = 0 menuTriangle
                    .addChild(currentMenu);
                this.app.stage.addChild(menuTriangle);
            }
        }
    }
</script>

<style>
    #id {
        /* text-align: center */
    }
</style>

2,index.vue,界面不够美观,我这个转盘还是花了好久去修改的,因为我本人不会ps,现学的。

<template>
    <view class="content">
        <!-- <image class="logo" src="/static/logo.png"></image> -->
        <view class="button-area">
            <button size='mini' @click='openDialog'>添加菜品</button>
            <button size='mini' @click='rorate'>转动</button>
        </view>

        <view class='menu'>
            <div class='menu-item' v-for='(item,index) in menu' :key='index'>
                <span>
                    <span>{{index +1}}:</span><span class='dish-name'>{{item.dishName}}</span>
                </span>
                <span>
                    <span class='edit-btn' @click='editDialog(item.dishName,item._id)'>编辑</span>
                    <span class='del-btn' @click='delDishName(item._id)'>删除</span>
                </span>
            </div>
        </view>
        <turntable ref='turntable' class='turn-con' :menu='menu'></turntable>
        <view class='pop' v-show='ifVisilble'>
            <form @submit="formSubmit" class='form-con'>
                <view class="input-con">
                    <span>菜单名称:</span>
                    <input class="uni-input" name="input" :value='dishName' placeholder="这是一个输入框" />
                </view>
                <view class="submit-btn">
                    <button size='mini' form-type="submit">提交</button>
                    <button size='mini' form-type="submit" @click='reset'>取消</button>
                </view>
            </form>
        </view>
    </view>
</template>

<script>
    import turntable from '../turntable/turntable.vue'
    export default {
        components: {
            turntable
        },

        data() {
            return {
                title: 'Hello',
                menu: [],
                ifVisilble: false,
                dishName: '',
                isEdit: false
            }
        },
        methods: {
            rorate() {
                this.$refs.turntable.rorate()
            },
            getMenuList(e) {
                uniCloud.callFunction({
                    name: 'menuList',
                    data: {
                        limit: 30,
                        offset: 0,
                        keyWord: e ? e.detail.value : ''
                    }
                }).then((res) => {
                    console.log('菜单', res.result.data)
                    this.menu = res.result.data
                })
            },
            formSubmit(e) {
                console.log('e', e.detail.value.input)
                if (this.isEdit) {
                    uniCloud.callFunction({
                        name: 'updateDishName',
                        data: {
                            id: this.id,
                            dishName: e.detail.value.input
                        }
                    }).then(res => this.getMenuList())
                } else {
                    uniCloud.callFunction({
                        name: 'addDishName',
                        data: {
                            dishName: e.detail.value.input
                        }
                    }).then(res => this.getMenuList())

                }
            },
            delDishName(id) {
                uniCloud.callFunction({
                    name: 'delDishName',
                    data: {
                        id
                    }
                })
                this.getMenuList()
            },
            reset() {
                this.dishName = ''
                this.ifVisilble = false
            },
            openDialog() {
                if (this.menu.length < 8) {
                    this.ifVisilble = true
                    this.dishName = ''
                    this.isEdit = false
                } else {
                    alert('只可以添加八个菜!')
                }

            },
            editDialog(dishName, id) {
                this.ifVisilble = true
                this.isEdit = true
                this.dishName = dishName
                this.id = id
            }
        },
        created() {
            this.getMenuList()
        }
    }
</script>

<style>
    .content {
        /* position: relative; */
    }

    .button-area {
        display: flex;
        justify-content: space-around;
        width: 100%;
        padding-top: 20px;
    }

    .title {
        font-size: 36rpx;
        color: #8f8f94;
    }

    .menu-item {
        display: inline-flex;
        justify-content: space-between;
        width: 50%;
        padding-bottom: 5px;
    }

    .edit-btn {
        padding-right: 5px;
        color: #4054e6b0;
    }

    .del-btn {
        padding-right: 5px;

        color: #e68540;
    }

    .dish-name {
        padding-left: 10px;
        color: #dc40e6
    }

    .menu {
        padding: 20px;
    }

    .input-con {
        display: flex;
        padding: 20px 20px;
    }

    .uni-input {
        border-bottom: 1px solid black;
        padding-left: 20px;
        width: 70%;
    }


    .submit-btn {
        text-align: right;
        padding-right: 20px;
    }

    .submit-btn :first-child {
        margin-right: 10px;
    }

    .turn-con {
        text-align: center;
        padding-top: 0px 20px 0 20px;
    }

    .pop {
        position: relative;
        top: -400px;
        background: #fff;
        padding: 20px 0;
        margin: 0 10px;
        border-radius: 10px;
        box-shadow: 5px 5px 5px #89898773;
    }
</style>

3,云函数文件我就写到一起了,后面大家自己写,可以分开。下面是文函数截图,再下面是里面的内容。有其他配置问题可以评论区问我。

 

 

'use strict'
const db = uniCloud.database()
exports.main = async (event, context) => {
    //event为客户端上传的参数
    console.log('event : ', event, context)
    let data = { dishName: event.dishName }
    await db.collection('menu').add(data)
    //返回数据给客户端
    return {
        code: 200,
        msg: '添加成功'
    }
}

'use strict'
const db = uniCloud.database()
exports.main = async (event, context) => {
    //event为客户端上传的参数
    console.log('event : ', event)
    const id = event.id
    const collection = db.collection('menu')
    const res = collection.doc(id).remove() //返回数据给客户端

    return {
        code: 200,
        msg: '删除成功'
    }
}

'use strict'
const db = uniCloud.database()
exports.main = async (event, context) => {
    //event为客户端上传的参数
    console.log('event : ', event)
    const collection = db.collection('menu') // 获取menu的集合对象
    console.log('collection : ', collection)
    const res = await collection.limit(event.limit).skip(event.offset).where({ dishName: new RegExp(event.keyWord) }).get()
    //返回数据给客户端
    return res
}



'use strict'
const db = uniCloud.database()
exports.main = async (event, context) => {
    //event为客户端上传的参数
    console.log('event : ', event)
    const id = event.id
    const dishName = event.dishName
    const collection = db.collection('menu')
    await collection.doc(id).update({ dishName })
    //返回数据给客户端
    return {
        code: 200,
        msg: '编辑成功'
    }
}

基本代码就是这样啦,细节不明白关注我,然后评论区问我,

posted @ 2022-11-09 11:53  sinceForever  阅读(681)  评论(2编辑  收藏  举报