mirror of
https://github.com/EsotericSoftware/spine-runtimes.git
synced 2025-12-21 01:36:02 +08:00
130 lines
5.3 KiB
HTML
130 lines
5.3 KiB
HTML
<html>
|
|
<script src="../../build/spine-widget.js"></script>
|
|
<script src="https://code.jquery.com/jquery-3.1.0.min.js"></script>
|
|
<body>
|
|
<center>
|
|
<!-- You can programmatically initialize a widget -->
|
|
<div id="spine-widget" style="margin-bottom: 20px; width: 640px; height: 480px;"></div>
|
|
<!-- You can also specify your own x/y and scale for the skeleton -->
|
|
<div style="margin-bottom: 20px; width: 100%; height: 150px;" class="spine-widget" data-json="assets/raptor-pro.json" data-atlas="assets/raptor-pma.atlas" data-animation="jump" data-fit-to-canvas="false" data-scale="0.1" data-x="200" data-y="10"></div>
|
|
<!-- Or make things real small -->
|
|
<div style="margin-bottom: 20px; width: 320px; height: 240px;" class="spine-widget" data-json="assets/raptor-pro.json" data-atlas="assets/raptor-pma.atlas" data-animation="walk" data-background-color="#cc0000"></div>
|
|
<!-- You can also specify the .JSON and .atlas files inline to reduce the number of requests made to the server -->
|
|
<div id="spine-widget-inline" style="margin-bottom: 20px; width: 640px; height: 480px;"></div>
|
|
</center>
|
|
</body>
|
|
|
|
<script id="atlas" type="text/plain">
|
|
spine-logo.png
|
|
size: 128,64
|
|
format: RGBA8888
|
|
filter: Linear,Linear
|
|
repeat: none
|
|
logo
|
|
rotate: false
|
|
xy: 2, 2
|
|
size: 104, 32
|
|
orig: 104, 32
|
|
offset: 0, 0
|
|
index: -1
|
|
</script>
|
|
|
|
<script id="atlasPage" type="text/plain">
|
|

|
|
</script>
|
|
|
|
<script id="json" type="text/plain">
|
|
{
|
|
"skeleton": { "hash": "MYXtB/H4Z2fp6J+/XZiyN+f9Hfc", "spine": "3.5.49", "width": 104, "height": 32, "images": "" },
|
|
"bones": [
|
|
{ "name": "root" }
|
|
],
|
|
"slots": [
|
|
{ "name": "spine-logo", "bone": "root", "attachment": "logo" }
|
|
],
|
|
"skins": {
|
|
"default": {
|
|
"spine-logo": {
|
|
"logo": { "width": 104, "height": 32 }
|
|
}
|
|
}
|
|
},
|
|
"animations": {
|
|
"animation": {
|
|
"bones": {
|
|
"root": {
|
|
"rotate": [
|
|
{ "time": 0, "angle": 0 },
|
|
{ "time": 0.8333, "angle": 39.96 },
|
|
{ "time": 1.6667, "angle": 0 }
|
|
],
|
|
"scale": [
|
|
{ "time": 0, "x": 1, "y": 1 },
|
|
{ "time": 0.8333, "x": 3, "y": 3 },
|
|
{ "time": 1.6667, "x": 1, "y": 1 }
|
|
]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<script>
|
|
function supportsWebGL() {
|
|
try {
|
|
var canvas = document.createElement("canvas");
|
|
var ctx = canvas.getContext("webgl") || canvas.getContext("experimental-webgl");
|
|
return ctx != null;
|
|
} catch(e) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
if (!supportsWebGL()) {
|
|
alert('WebGL is unavailable.');
|
|
}
|
|
|
|
spineWidget = new spine.SpineWidget("spine-widget", {
|
|
json: "assets/spineboy-pro.json",
|
|
atlas: "assets/spineboy-pma.atlas",
|
|
animation: "run",
|
|
backgroundColor: "#00000000",
|
|
debug: true,
|
|
success: function (widget) {
|
|
var animIndex = 0;
|
|
widget.canvas.onclick = function () {
|
|
animIndex++;
|
|
var animations = widget.skeleton.data.animations;
|
|
if (animIndex >= animations.length) animIndex = 0;
|
|
widget.setAnimation(animations[animIndex].name);
|
|
}
|
|
}
|
|
});
|
|
|
|
json = document.getElementById("json").innerHTML;
|
|
atlas = document.getElementById("atlas").innerHTML;
|
|
atlasPageContent = document.getElementById("atlasPage").innerHTML;
|
|
|
|
spineWidgetInline = new spine.SpineWidget("spine-widget-inline", {
|
|
jsonContent: json,
|
|
atlasContent: atlas,
|
|
atlasPages: ["spine-logo.png"],
|
|
atlasPagesContent: [atlasPageContent],
|
|
animation: "animation",
|
|
backgroundColor: "#00000000",
|
|
debug: true,
|
|
success: function (widget) {
|
|
var animIndex = 0;
|
|
widget.canvas.onclick = function () {
|
|
animIndex++;
|
|
let animations = widget.skeleton.data.animations;
|
|
if (animIndex >= animations.length) animIndex = 0;
|
|
widget.setAnimation(animations[animIndex].name);
|
|
}
|
|
}
|
|
});
|
|
|
|
</script>
|
|
</body>
|
|
</html> |