小六教你用ReactNative做一个拼图游戏(一) 切了只猫猫..

最近ReactNative的协议风波,好像很多大公司都准备放弃使用ReactNative

不过题主还是非常喜欢使用ReactNative,为啥?方便呗。这里不过多的描述ReactNative的太多基础知识。

相关环境搭建ReactNative网站还是说的很多的。

直接进入主题,咱们先搞点事情出来再说。

//TODO GIF

第一次发博客,排版各种功能都在学习中,大家见谅。

项目搭建和基本环境

 咱们先初始化一个项目

{
  react-native-cli: 2.0.1,
  react-native: 0.49.3
}

 

图片分割分配,静态布局

首先删掉原先的部分代码,咱们做一个和屏幕宽度相同的View,放在屏幕中间,再加上一个风骚的颜色背景,我们会看的更加清楚(部分代码)

const WIDTH = Dimensions.get("window").width;
<View style={styles.container}>
       <View style={styles.canvas}>
             <Text>{WIDTH}</Text>
     </View>
</View>
const styles = StyleSheet.create({
        container: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
        },
        canvas: {
            width: WIDTH,
            height: WIDTH,
            backgroundColor: "red",
        },

    })
;

  

下一步就是布局出我们需要的3*3图片方正

 图片我们用base64,这样使用起来更加方便。

首先我们需要一个帮助我们处理工具方法

 具体用法 通过传入JSON参数 offset为起点  size为需要切割的图片大小

完成切割以后的代码如下

 

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


const _IMG = "";

//转换成Promise  我们会用的更加方便
const cropImage = function (img, cropData) {
    return new Promise(function (resolve, reject) {
        ImageEditor.cropImage(img, cropData, resolve, reject);

    });
}
const getSize = function (img) {

    return new Promise(function (resolve, reject) {
        Image.getSize(img, (width, height) => {
            resolve({width, height})
        }, reject);

    });
}


const imageSlicing = async function (base64Code) {
    //好习惯,首先写返回值
    let result = [];
    //获取图片宽和高
    let {width: imgWidth, height: imgHeight} = await getSize(base64Code);
    //进行切割 3*3布局
    // 基本功两次循环

    let _column = 3;
    let _row = 3;
    let _columnWidth = imgWidth / _column;
    let _rowHeight = imgHeight / _row;

    let cropData = [];
    for (let r = 0; r < _row; r++) {
        for (let c = 0; c < _column; c++) {
            let _cropData = {
                offset: {
                    x: c * _columnWidth,
                    y: r * _rowHeight,
                },
                size: {
                    width: _columnWidth,
                    height: _rowHeight,
                },
            }
            console.log(_cropData.offset.x);
            let uri = await cropImage(base64Code, _cropData);
            result.push(uri);
        }


    }
    return result;

}


export default class App extends Component<{}> {

    constructor() {
        super();
        this.state = {
            myUrl: {uri: _IMG},
            imgList: [],
        }
        let _this = this;

        imageSlicing(_IMG).then((json) => {
            this.setState({imgList: json});
        });

    }

    renderImage() {

        return
    }


    render() {
        return (
            <View style={styles.container}>
                <ScrollView style={styles.canvas}>
                    {/*<Image  source={this.state.myUrl}></Image>*/}
                    {this.state.imgList.map((uri, index) => {
                        return (
                            <Image style={styles.imageTest} key={index} source={{uri: uri}}/>
                        )
                    })}
                </ScrollView>
            </View>
        );
    }
}

const styles = StyleSheet.create({
        container: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
        },
        canvas: {
            flex: 1
        },
        imageTest: {
            width: WIDTH/3,
            height: WIDTH/3,
        }

    })
;

  效果如下

可爱的猫猫被我们肢解了  好惨~

第一节到此为止,之后会介绍接下来的步骤

 

posted on 2017-10-10 17:07  刘成帅  阅读(864)  评论(0编辑  收藏  举报

导航