A vue component to create a slide puzzle game, be aware that this plugin need to install sass related loader.
Mobile touch events supported.
See Live Demo
npm install vue-slide-puzzle
// or
yarn add vue-slide-puzzle
import component
import { VueSlidePuzzle } from 'vue-slide-puzzle';
import 'vue-slide-puzzle/dist/VueSlidePuzzle.css';
export default {
components: {
VueSlidePuzzle
}
};
<template>
<div id="app">
<!-- Give a wrapper to set width, height for puzzle -->
<div style="width: 400px;height: 300px;">
<slide-puzzle :ratio="3" mode="near" />
</div>
</div>
</template>
<script>
import { VueSlidePuzzle } from 'vue-slide-puzzle';
import 'vue-slide-puzzle/dist/VueSlidePuzzle.css';
export default {
components: {
VueSlidePuzzle
}
};
</script>
puzzle number(default: 3^2 => 9)
- type:
Number
- default: 3
puzzle init shuffle steps
- type:
Number
- default: 5
puzzle wrapper css styles
- type:
Object
- default:
{
"width": "100%",
"height": "100%",
}
puzzle image url, will be watched
inside the component once changed value. So could be used to rerender the puzzle. See Live Demo Source Code
- type:
String
- default:
https://static.toiimg.com/photo/72975551.cms
puzzle move mode
- type:
String
- default:
near
- allowed values:
near
,far
,free
if the excluded puzzle should be random
- type:
Boolean
- default:
false
(default is first puzzle get excluded)
Here is the events list, each will be trigger after the plugin.
emits: [
'card-dragstart',
'card-dragenter',
'card-dragleave',
'card-dragover',
'card-drop',
'card-touchmove',
'card-touchend'
]
If we want to count the user's steps, we can use card-drop
and card-touchend
, which will only trigger after the plugin check.
<template>
<div id="app">
<p>User steps count: {{ count }}</p>
<div style="width: 400px;height: 300px;">
<slide-puzzle
:ratio="3"
mode="near"
@card-drop="onUserMoved"
@card-touchend="onUserMoved"
/>
</div>
</div>
</template>
<script>
import { VueSlidePuzzle } from 'vue-slide-puzzle';
export default {
components: {
VueSlidePuzzle
},
data() {
return {
count: 0,
};
},
methods: {
onUserMoved() {
this.count++;
},
},
};
</script>
Copyright (c) 2020-present, Johnny Wang