-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
b8f45e6
commit 68275b0
Showing
31 changed files
with
1,803 additions
and
1,729 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
{"links":[{"namespace":"bandage","pattern":"/bandage/recipes#:ref"}],"items":[{"id":"bandage:bandage","name":"Bandage","texture":""},{"id":"bandage:nether_bandage","name":"Nether Bandage","texture":""},{"id":"bandage:end_bandage","name":"End Bandage","texture":""},{"id":"bandage:water_bandage","name":"Water Bandage","texture":""}]} |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
import * as THREE from "three"; | ||
|
||
export class BedrockGeoLoader extends THREE.Loader { | ||
constructor(manager) { | ||
super(manager); | ||
} | ||
|
||
load(url) { | ||
const onError = () => {}; | ||
const onProgress = () => {}; | ||
const scope = this; | ||
const loader = new THREE.FileLoader(scope.manager); | ||
loader.setPath(scope.path); | ||
loader.setRequestHeader(scope.requestHeader); | ||
loader.setWithCredentials(scope.withCredentials); | ||
loader.load( | ||
url, | ||
function (text) { | ||
try { | ||
console.log(text); | ||
scope.parse(JSON.parse(text)); | ||
} catch (e) { | ||
if (onError) { | ||
onError(e); | ||
} else { | ||
console.error(e); | ||
} | ||
|
||
scope.manager.itemError(url); | ||
} | ||
}, | ||
onError, | ||
onProgress | ||
); | ||
} | ||
|
||
parse(json) { | ||
console.log(json); | ||
|
||
return undefined; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
|
||
export class Identifier { | ||
constructor(namespace, path) { | ||
this.namespace = namespace; | ||
this.path = path; | ||
} | ||
|
||
static fromString(namespace, path) { | ||
if (path == undefined) { | ||
if (namespace instanceof Identifier) {return namespace} | ||
var namespace2, path2; | ||
[namespace2, path2] = namespace.toString().split(":"); | ||
if (!path2) { | ||
return new Identifier("minecraft", namespace); | ||
} | ||
return new Identifier(namespace2, path2); | ||
} | ||
return new Identifier(namespace, path2); | ||
} | ||
|
||
match(other) { | ||
if (other instanceof Identifier) { | ||
return this.namespace === other.namespace && this.path === other.path; | ||
} | ||
return this.match(Identifier.fromString(other)); | ||
} | ||
|
||
toString() { | ||
return this.namespace + ":" + this.path; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
import { Identifier } from "./Identifier"; | ||
import { renderFormatting, getLink } from "../theme/mcui"; | ||
|
||
export class Item { | ||
constructor(id, name, texture, link, lore = []) { | ||
this.id = id; | ||
this.name = name; | ||
this.link = link; | ||
this.texture = texture | ||
? texture | ||
: ""; | ||
this.lore = lore; | ||
} | ||
static unknown() { | ||
return new Item( | ||
Identifier.fromString("unknown"), | ||
"Unknown", | ||
"" | ||
); | ||
} | ||
|
||
// parse item | ||
static fromJson(data) { | ||
return new Item( | ||
Identifier.fromString(data.id), | ||
data.name, | ||
data.texture, | ||
data.link, | ||
data.lore | ||
); | ||
} | ||
|
||
match(other) { | ||
if (other instanceof Item) { | ||
return this.id.match(other.id); | ||
} | ||
return false; | ||
} | ||
|
||
toString() { | ||
return this.id.toString(); | ||
} | ||
|
||
cleanName() { | ||
if (!this._cleanName) { | ||
this._cleanName = this.name.replace(/§./g, ''); | ||
} | ||
return this._cleanName; | ||
} | ||
|
||
getDisplayName() { | ||
if (!this.displayName) { | ||
this.displayName = renderFormatting(this.name); | ||
} | ||
return this.displayName; | ||
} | ||
|
||
getMinetip() { | ||
if (!this.minetip) { | ||
// Name | ||
this.minetip = this.getDisplayName() + "<br>"; | ||
// Lore | ||
var htmlLore = []; | ||
if (this.lore) { | ||
for (const ln of this.lore) { | ||
htmlLore.push(renderFormatting(ln)); | ||
} | ||
} | ||
// Advanced Tooltips | ||
htmlLore.push('<span class="format-8">' + this.id.toString() + "</span>"); | ||
this.minetip += htmlLore.join("<br>"); | ||
} | ||
return this.minetip; | ||
} | ||
|
||
getLink() { | ||
if (!this.link) { | ||
var link = getLink(this); | ||
this.link = link ? link : "#" + this.id.path; | ||
} | ||
return this.link; | ||
} | ||
|
||
getLinkTarget() { | ||
if (!this.linkTarget) { | ||
this.linkTarget = this.getLink().startsWith("http") ? "_blank" : "_self"; | ||
} | ||
return this.linkTarget; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,148 @@ | ||
<!-- WARN: Not ready for production!! --> | ||
|
||
<template> | ||
<div id="renderer"></div> | ||
</template> | ||
|
||
<script> | ||
import * as THREE from "three"; | ||
import { OrbitControls } from "three/addons/controls/OrbitControls.js"; | ||
import { GUI } from "three/addons/libs/lil-gui.module.min.js"; | ||
import { BedrockGeoLoader } from "../classes/BedrockGeoLoader.js"; | ||
// https://threejs.org/docs/#manual/en/introduction/Installation | ||
export default { | ||
name: "ArmorStandGenerator", | ||
data() { | ||
return {}; | ||
}, | ||
methods: { | ||
init: function () { | ||
const armorStand = new BedrockGeoLoader().load( | ||
"../theme/models/armor_stand.geo.json", | ||
"geometry.armor_stand" | ||
); | ||
let container = document.getElementById("renderer"); | ||
this.scene = new THREE.Scene(); | ||
this.camera = new THREE.PerspectiveCamera( | ||
75, | ||
container.clientWidth / container.clientHeight, | ||
0.1, | ||
1000 | ||
); | ||
this.renderer = new THREE.WebGLRenderer(); | ||
this.renderer.setSize(container.clientWidth, container.clientHeight); | ||
container.appendChild(this.renderer.domElement); | ||
// Cube | ||
const geometry = new THREE.BoxGeometry(1, 1, 1); | ||
const material = new THREE.MeshLambertMaterial({ color: 0xff0000 }); | ||
this.cube = new THREE.Mesh(geometry, material); | ||
this.scene.add(this.cube); | ||
// Light | ||
const ambientLight = new THREE.AmbientLight(0xffffff, 0.5); | ||
const light = new THREE.SpotLight(0xffffff, 200); | ||
light.position.set(0, 0, 1); | ||
this.scene.add(ambientLight, light); | ||
this.lightHolder = new THREE.Group(); | ||
this.lightHolder.add(light); | ||
this.scene.add(this.lightHolder); | ||
// Controls | ||
this.camera.position.set(0, 0, 5); | ||
const controls = new OrbitControls(this.camera, this.renderer.domElement); | ||
controls.enablePan = false; | ||
controls.enableZoom = false; | ||
this.createPanel(); | ||
}, | ||
createPanel() { | ||
const gui = new GUI({ container: document.getElementById("renderer") }); | ||
const head = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const body = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const leftArm = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const rightArm = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const leftLeg = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const rightLeg = { | ||
x: 0, | ||
y: 0, | ||
z: 0, | ||
}; | ||
const headFolder = gui.addFolder("Head"); | ||
headFolder.add(head, "x", 0, 360, 1); | ||
headFolder.add(head, "y", 0, 360, 1); | ||
headFolder.add(head, "z", 0, 360, 1); | ||
const bodyFolder = gui.addFolder("Body"); | ||
bodyFolder.add(body, "x", 0, 360, 1); | ||
bodyFolder.add(body, "y", 0, 360, 1); | ||
bodyFolder.add(body, "z", 0, 360, 1); | ||
const leftArmFolder = gui.addFolder("Left Arm"); | ||
leftArmFolder.add(leftArm, "x", 0, 360, 1); | ||
leftArmFolder.add(leftArm, "y", 0, 360, 1); | ||
leftArmFolder.add(leftArm, "z", 0, 360, 1); | ||
const rightArmFolder = gui.addFolder("Right Arm"); | ||
rightArmFolder.add(rightArm, "x", 0, 360, 1); | ||
rightArmFolder.add(rightArm, "y", 0, 360, 1); | ||
rightArmFolder.add(rightArm, "z", 0, 360, 1); | ||
const leftLegFolder = gui.addFolder("Left Leg"); | ||
leftLegFolder.add(leftLeg, "x", 0, 360, 1); | ||
leftLegFolder.add(leftLeg, "y", 0, 360, 1); | ||
leftLegFolder.add(leftLeg, "z", 0, 360, 1); | ||
const rightLegFolder = gui.addFolder("Right Leg"); | ||
rightLegFolder.add(rightLeg, "x", 0, 360, 1); | ||
rightLegFolder.add(rightLeg, "y", 0, 360, 1); | ||
rightLegFolder.add(rightLeg, "z", 0, 360, 1); | ||
gui.onChange((event) => { | ||
console.log(event.property); | ||
}); | ||
gui.open(); | ||
}, | ||
animate: function () { | ||
requestAnimationFrame(this.animate); | ||
// this.cube.rotation.x += 0.01; | ||
// this.cube.rotation.y += 0.01; | ||
this.lightHolder.quaternion.copy(this.camera.quaternion); | ||
this.renderer.render(this.scene, this.camera); | ||
}, | ||
}, | ||
mounted() { | ||
this.init(); | ||
this.animate(); | ||
}, | ||
}; | ||
</script> | ||
|
||
<style scoped> | ||
#renderer { | ||
display: block; | ||
width: 500px; | ||
height: 500px; | ||
cursor: move; | ||
} | ||
</style> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
<template> | ||
<div class="BisectHostingAds">ADVERT</div> | ||
</template> | ||
|
||
<script> | ||
export default { | ||
name: "BisectHostingAds", | ||
}; | ||
</script> | ||
|
||
<style scoped> | ||
.BisectHostingAds { | ||
display: flex; | ||
justify-content: center; | ||
align-items: center; | ||
padding: 24px; | ||
border-radius: 12px; | ||
min-height: 256px; | ||
text-align: center; | ||
line-height: 18px; | ||
font-size: 12px; | ||
font-weight: 500; | ||
background-color: var(--vp-carbon-ads-bg-color); | ||
} | ||
</style> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
<template> | ||
<div> | ||
<span class="mcui mcui-Brewing pixel-image"> | ||
<span class="mcui-input"> | ||
<InvSlot :id="input" /> | ||
</span> | ||
<span class="mcui-output"> | ||
<InvSlot /> | ||
<InvSlot :id="output" /> | ||
<InvSlot /> | ||
</span> | ||
</span> | ||
</div> | ||
</template> | ||
|
||
<script> | ||
export default { | ||
name: "BrewingRecipe", | ||
props: { | ||
input: String, | ||
output: String, | ||
}, | ||
}; | ||
</script> | ||
|
||
<style scoped></style> |
Oops, something went wrong.