小六教你用ReactNative做一个拼图游戏(三) 添加动作

先看效果

我们继续

 

之前我们做好了所有准备工作,

现在我们对这个图片添加动作。

思路

我们知道,空白块只有一个,而此时能够上移,右移,下移,左移的只有一个。

我们需要时时刻刻吧块记一下。

我们添加以下代码。

_getActBox() {
        //找到空白块
        let blackBox = this.state.imgList.find((element) => {
            return element.isNull;
        });

        let c = blackBox.currentIndex;
        //当前在第几行
        let c_r = parseInt(c / 3);
        //当前在第几列
        let c_c = c % 3;

        let findElement = (r, c) => {
            return this.state.imgList.find((element) => {


                return element.currentIndex == (r * 3 + c);
            })
        };

        //正上方
        this.actBox.up = c_r > 0 ? findElement(c_r - 1, c_c) : {};
        this.actBox.down = c_r < 2 ? findElement(c_r + 1, c_c) : {};
        this.actBox.left = c_c > 0 ? findElement(c_r, c_c - 1) : {};
        this.actBox.right = c_c < 2 ? findElement(c_r, c_c + 1) : {};

        console.log("up", this.actBox.up.currentIndex);
        console.log("down", this.actBox.down.currentIndex);
        console.log("left", this.actBox.left.currentIndex);
        console.log("right", this.actBox.right.currentIndex);
    }

  

这个时候我们就时时刻刻的知道了,当前哪些块进行移动

移动方法

说到底,移动无非是方块的交换,我们计算好方块的交换

代码如下

 _move(direction) {

        let blackBox = this.state.imgList.find((element) => {
            return element.isNull;
        });

        let changeBoxCurrentIndex = (box1Index, box2Index) => {

            if (box1Index == undefined || box2Index == undefined) {
                return;
            }


            let imgList = this.state.imgList;

            console.log("box1", box1Index);
            console.log("box2", box2Index);
            let box1 = imgList.find((element) => element.currentIndex == box1Index);
            let box2 = imgList.find((element) => element.currentIndex == box2Index);
            let temp = box1.currentIndex;
            box1.currentIndex = box2.currentIndex;
            box2.currentIndex = temp;
            this.setState({imgList: imgList}, (() => {
                this._getActBox();
            }).bind(this));


        }


        switch (direction) {
            case "up":
                changeBoxCurrentIndex(this.actBox.down.currentIndex, blackBox.currentIndex);
                break;
            case "down":
                changeBoxCurrentIndex(this.actBox.up.currentIndex, blackBox.currentIndex);
                break;
            case "left":
                changeBoxCurrentIndex(this.actBox.right.currentIndex, blackBox.currentIndex);
                break;
            case "right":
                changeBoxCurrentIndex(this.actBox.left.currentIndex, blackBox.currentIndex);
                break;
        }

    }

  

整体效果就会如GIF图所表。

 

完整代码

import React, {Component} from 'react';
import {
    Platform,
    StyleSheet,
    Dimensions,
    ScrollView,
    Text,
    ImageEditor,
    Button,
    Image,
    View
} from 'react-native';
import Croper from "./Croper";
const WIDTH = Dimensions.get("window").width;


const _IMG = "";


export default class App extends Component<{}> {


    constructor() {
        super();
        this.state = {
            myUrl: {uri: _IMG},
            imgList: [],
        }
        let _this = this;
        let croper = new Croper(_IMG);
        croper.crop(3, 3).then((json) => {


            this.setState({imgList: this._upset(json.imageList)});
            this._getActBox();
        });


        //存放哪些块
        this.actBox = {
            up: {},
            down: {},
            left: {},
            right: {},
        }
    }


    //打乱图片  并且加上索引  抠出最后一张图
    _upset(arr) {
        let result = arr;
        let indexList = [];
        for (let i = 0; i < arr.length; i++) {
            indexList.push(i);
        }
        //打乱顺序
        indexList = indexList.sort(function () {
            return (0.5 - Math.random());
        });
        for (let i = 0; i < arr.length; i++) {
            result[i].currentIndex = indexList[i];
            if (indexList[i] == arr.length - 1) {
                result[i].isNull = true;
            }
        }

        return result;
    }


    _getActBox() {
        //找到空白块
        let blackBox = this.state.imgList.find((element) => {
            return element.isNull;
        });

        let c = blackBox.currentIndex;
        //当前在第几行
        let c_r = parseInt(c / 3);
        //当前在第几列
        let c_c = c % 3;

        let findElement = (r, c) => {
            return this.state.imgList.find((element) => {


                return element.currentIndex == (r * 3 + c);
            })
        };

        //正上方
        this.actBox.up = c_r > 0 ? findElement(c_r - 1, c_c) : {};
        this.actBox.down = c_r < 2 ? findElement(c_r + 1, c_c) : {};
        this.actBox.left = c_c > 0 ? findElement(c_r, c_c - 1) : {};
        this.actBox.right = c_c < 2 ? findElement(c_r, c_c + 1) : {};

        console.log("up", this.actBox.up.currentIndex);
        console.log("down", this.actBox.down.currentIndex);
        console.log("left", this.actBox.left.currentIndex);
        console.log("right", this.actBox.right.currentIndex);
    }

    _move(direction) {

        let blackBox = this.state.imgList.find((element) => {
            return element.isNull;
        });

        let changeBoxCurrentIndex = (box1Index, box2Index) => {

            if (box1Index == undefined || box2Index == undefined) {
                return;
            }


            let imgList = this.state.imgList;

            console.log("box1", box1Index);
            console.log("box2", box2Index);
            let box1 = imgList.find((element) => element.currentIndex == box1Index);
            let box2 = imgList.find((element) => element.currentIndex == box2Index);
            let temp = box1.currentIndex;
            box1.currentIndex = box2.currentIndex;
            box2.currentIndex = temp;
            this.setState({imgList: imgList}, (() => {
                this._getActBox();
            }).bind(this));


        }


        switch (direction) {
            case "up":
                changeBoxCurrentIndex(this.actBox.down.currentIndex, blackBox.currentIndex);
                break;
            case "down":
                changeBoxCurrentIndex(this.actBox.up.currentIndex, blackBox.currentIndex);
                break;
            case "left":
                changeBoxCurrentIndex(this.actBox.right.currentIndex, blackBox.currentIndex);
                break;
            case "right":
                changeBoxCurrentIndex(this.actBox.left.currentIndex, blackBox.currentIndex);
                break;
        }

    }


    render() {
        return (
            <View style={styles.container}>
                <View style={{flex: 1}}>
                    {this.state.imgList.map((img, index) => {
                        if (img.isNull) return null;
                        return (
                            <Image style={{
                                width: img.fullWidth,
                                height: img.fullHeight,
                                position: "absolute",

                                top: parseInt(img.currentIndex / 3) * img.fullHeight,
                                left: img.currentIndex % 3 * img.fullWidth,
                                borderWidth: 1,
                                borderColor: "#000000"
                            }} key={index}
                                   source={{uri: img.uri}}/>
                        )
                    })}
                </View>

                <View style={{flexDirection: "row"}}>
                    <Button title="↑" onPress={this._move.bind(this, "up")}></Button>
                    <Button title="↓" onPress={this._move.bind(this, "down")}></Button>
                    <Button title="←" onPress={this._move.bind(this, "left")}></Button>
                    <Button title="→" onPress={this._move.bind(this, "right")}></Button>
                </View>
            </View>
        );
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,

    },
    opView: {},
    canvas: {
        flex: 1
    },


});

  

有没有发现使用按钮感觉还是不太舒服。

我们下一节即将调整。加入动画效果和使用触屏移动方式。

 

posted on 2017-10-18 16:47  刘成帅  阅读(878)  评论(0)    收藏  举报

导航