{"id":86,"date":"2026-04-19T14:49:41","date_gmt":"2026-04-19T06:49:41","guid":{"rendered":"https:\/\/www.sjll.top\/index.php\/2026\/04\/19\/%e6%8a%80%e6%9c%af%e8%a7%a3%e6%9e%90%ef%bc%9ax1aozhe-%e7%9a%84%e5%83%8f%e7%b4%a0%e4%b8%96%e7%95%8c-%e7%bb%88%e5%b1%80%e4%b9%8b%e6%88%98\/"},"modified":"2026-04-19T14:49:41","modified_gmt":"2026-04-19T06:49:41","slug":"%e6%8a%80%e6%9c%af%e8%a7%a3%e6%9e%90%ef%bc%9ax1aozhe-%e7%9a%84%e5%83%8f%e7%b4%a0%e4%b8%96%e7%95%8c-%e7%bb%88%e5%b1%80%e4%b9%8b%e6%88%98","status":"publish","type":"post","link":"https:\/\/www.sjll.top\/?p=86","title":{"rendered":"\u6280\u672f\u89e3\u6790\uff1aX1aoZhe \u7684\u50cf\u7d20\u4e16\u754c &#8211; \u7ec8\u5c40\u4e4b\u6218"},"content":{"rendered":"\n<h1 class=\"wp-block-heading\">\u6280\u672f\u89e3\u6790\uff1aX1aoZhe \u7684\u50cf\u7d20\u4e16\u754c &#8211; \u7ec8\u5c40\u4e4b\u6218<\/h1>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfaf \u9879\u76ee\u6982\u8ff0<\/h2>\n\n\n\n<p><strong>\u300a\u50cf\u7d20\u4e16\u754c &#8211; \u7ec8\u5c40\u4e4b\u6218\u300b<\/strong> \u662f\u4e00\u6b3e\u57fa\u4e8e <strong>Vanilla JS + Three.js<\/strong> \u5f00\u53d1\u7684 3D \u50cf\u7d20\u98ce\u683c\u6e38\u620f\uff0c\u5b8c\u5168\u5728\u6d4f\u89c8\u5668\u4e2d\u8fd0\u884c\u3002\u8fd9\u662f\u4e00\u4e2a\u57fa\u4e8e AI \u7f16\u5199\u4ee3\u7801\u5e76\u8fdb\u884c\u4e8c\u6b21\u4f18\u5316\u7684\u4f5c\u54c1\uff0c\u5c55\u793a\u4e86\u73b0\u4ee3 Web \u6280\u672f\u5728\u6e38\u620f\u5f00\u53d1\u4e2d\u7684\u5f3a\u5927\u80fd\u529b\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u6838\u5fc3\u6280\u672f\u6808<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u6e32\u67d3\u5f15\u64ce<\/strong>\uff1aThree.js (r160.0)<\/li><li><strong>\u7f16\u7a0b\u8bed\u8a00<\/strong>\uff1aJavaScript (ES6+)<\/li><li><strong>\u566a\u58f0\u7b97\u6cd5<\/strong>\uff1asimplex-noise (\u7528\u4e8e\u5730\u5f62\u751f\u6210)<\/li><li><strong>\u4ea4\u4e92\u63a7\u5236<\/strong>\uff1aPointerLockControls<\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfd7\ufe0f \u67b6\u6784\u8bbe\u8ba1<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u591a\u7ef4\u5ea6\u4e16\u754c\u7cfb\u7edf<\/h3>\n\n\n\n<p>\u6e38\u620f\u5b9e\u73b0\u4e86\u4e09\u4e2a\u72ec\u7acb\u7684\u4e16\u754c\u7ef4\u5ea6\uff0c\u6bcf\u4e2a\u7ef4\u5ea6\u62e5\u6709\u72ec\u7acb\u7684\u6570\u636e\u72b6\u6001\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const dimensionState = {\n    overworld: { chunks: new Map(), worldBlocks: new Set(), entities: [], playerPos: null },\n    nether: { chunks: new Map(), worldBlocks: new Set(), entities: [], playerPos: null },\n    end: { chunks: new Map(), worldBlocks: new Set(), entities: [], playerPos: null }\n};<\/code><\/pre>\n\n\n\n<p><strong>\u8bbe\u8ba1\u4eae\u70b9<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>\u4f7f\u7528 <code>Map<\/code> \u5b58\u50a8\u533a\u5757\u6570\u636e\uff0c\u652f\u6301\u5feb\u901f\u67e5\u627e<\/li><li><code>Set<\/code> \u5b58\u50a8\u4e16\u754c\u65b9\u5757\uff0c\u4fbf\u4e8e\u5feb\u901f\u5224\u65ad\u65b9\u5757\u662f\u5426\u5b58\u5728<\/li><li>\u72ec\u7acb\u7684\u5b9e\u4f53\u7cfb\u7edf\uff0c\u6bcf\u4e2a\u7ef4\u5ea6\u6709\u81ea\u5df1\u7684\u5b9e\u4f53\u5217\u8868<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u533a\u5757\u7cfb\u7edf (Chunk System)<\/h3>\n\n\n\n<p>\u6e38\u620f\u91c7\u7528\u7ecf\u5178\u7684\u533a\u5757\u751f\u6210\u7b56\u7565\uff0c\u6bcf\u4e2a\u533a\u5757\u5927\u5c0f\u4e3a 16\u00d716\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const chunkSize = 16;<\/code><\/pre>\n\n\n\n<p><strong>\u533a\u5757\u6570\u636e\u7ed3\u6784<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const chunk = {\n    blocks: new Map(),  \/\/ \u5b58\u50a8\u65b9\u5757: \"x,y,z\" -&gt; blockType\n    mesh: null,         \/\/ Three.js \u7f51\u683c\u5bf9\u8c61\n    position: { x, z }  \/\/ \u533a\u5757\u5750\u6807\n};<\/code><\/pre>\n\n\n\n<p><strong>\u4f18\u52bf<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>\u53ea\u751f\u6210\u73a9\u5bb6\u9644\u8fd1\u7684\u533a\u5757\uff0c\u8282\u7701\u5185\u5b58<\/li><li>\u652f\u6301\u52a8\u6001\u52a0\u8f7d\u548c\u5378\u8f7d<\/li><li>\u63d0\u9ad8\u6e32\u67d3\u6027\u80fd<\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfa8 \u6e32\u67d3\u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u52a8\u6001\u7eb9\u7406\u751f\u6210<\/h3>\n\n\n\n<p>\u6e38\u620f\u4f7f\u7528 Canvas API \u52a8\u6001\u751f\u6210\u50cf\u7d20\u7eb9\u7406\uff0c\u65e0\u9700\u5916\u90e8\u56fe\u7247\u8d44\u6e90\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function createPixelTexture(type) {\n    const canvas = document.createElement('canvas');\n    canvas.width = 16;\n    canvas.height = 16;\n    const ctx = canvas.getContext('2d');\n\n    \/\/ \u4f7f\u7528\u566a\u58f0\u7b97\u6cd5\u751f\u6210\u7eb9\u7406\u7ec6\u8282\n    const noise = textureNoise2D(x, y, scale, seed);\n\n    \/\/ \u6839\u636e\u65b9\u5757\u7c7b\u578b\u751f\u6210\u4e0d\u540c\u7684\u989c\u8272\u548c\u7eb9\u7406\n    if (type === 'grass') {\n        \/\/ \u8349\u65b9\u5757\u9876\u90e8 - \u7eff\u8272\u6e10\u53d8 + \u968f\u673a\u6591\u70b9\n        const baseG = 140 + noise * 30;\n        r = 95 + noise;\n        g = Math.min(255, baseG + noise);\n        b = 45 + noise * 0.5;\n    }\n    \/\/ ... \u5176\u4ed6\u65b9\u5757\u7c7b\u578b\n}<\/code><\/pre>\n\n\n\n<p><strong>\u7eb9\u7406\u7279\u70b9<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>16\u00d716 \u50cf\u7d20\u5206\u8fa8\u7387<\/li><li>\u4f7f\u7528\u591a\u5c42\u566a\u58f0\u53e0\u52a0\u751f\u6210\u81ea\u7136\u7eb9\u7406<\/li><li>\u652f\u6301\u8fb9\u7f18\u9634\u5f71\u3001\u5e74\u8f6e\u3001\u88c2\u7f1d\u7b49\u7ec6\u8282<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u6027\u80fd\u4f18\u5316\u7b56\u7565<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\">\u89c6\u9525\u4f53\u5254\u9664 (Frustum Culling)<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function updateFrustum() {\n    projScreenMatrix.multiplyMatrices(camera.projectionMatrix, camera.matrixWorldInverse);\n    frustum.setFromProjectionMatrix(projScreenMatrix);\n}\n\nfunction isChunkVisible(cx, cz) {\n    \/\/ \u53ea\u6e32\u67d3\u76f8\u673a\u89c6\u91ce\u5185\u7684\u533a\u5757\n    const box = new THREE.Box3(\n        new THREE.Vector3(cx * chunkSize, camera.position.y - 12, cz * chunkSize),\n        new THREE.Vector3((cx + 1) * chunkSize, camera.position.y + 12, (cz + 1) * chunkSize)\n    );\n    return frustum.intersectsBox(box);\n}<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\">LOD (Level of Detail) \u7cfb\u7edf<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const LOD_DISTANCES = {\n    NEAR: 16,    \/\/ 16\u683c\u5185\uff1a\u5b8c\u6574\u7ec6\u8282\n    MEDIUM: 32,  \/\/ 32\u683c\u5185\uff1a\u4e2d\u7b49\u7ec6\u8282\n    FAR: 48      \/\/ 48\u683c\u5185\uff1a\u4f4e\u7ec6\u8282\n};<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\">\u5ef6\u8fdf\u7f51\u683c\u91cd\u5efa<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const rebuildQueue = new Set();\nlet lastRebuildTime = 0;\nconst REBUILD_INTERVAL = 50;\n\nfunction rebuildChunkMesh(chunk) {\n    if (Date.now() - lastRebuildTime &gt; REBUILD_INTERVAL) {\n        rebuildQueue.add(chunk);\n        lastRebuildTime = Date.now();\n    }\n}<\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\">\u5b9e\u4f53\u7a7a\u95f4\u5206\u533a<\/h4>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const entityGrid = new Map();\nconst ENTITY_GRID_SIZE = 32;\n\n\/\/ \u4f7f\u7528\u7f51\u683c\u5206\u533a\u52a0\u901f\u5b9e\u4f53\u78b0\u649e\u68c0\u6d4b<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83e\uddf1 \u65b9\u5757\u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u65b9\u5757\u6570\u636e\u5b57\u5178<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const ITEMS = {\n    grass: { type: 'block', hardness: 0.6, tool: 'none', tier: 0 },\n    stone: { type: 'block', hardness: 5.0, tool: 'pickaxe', tier: 1 },\n    diamond_ore: { type: 'block', hardness: 12.0, tool: 'pickaxe', tier: 3 },\n    obsidian: { type: 'block', hardness: 50.0, tool: 'pickaxe', tier: 3 },\n\n    wooden_pickaxe: { type: 'tool', toolType: 'pickaxe', tier: 1, power: 4 },\n    stone_pickaxe: { type: 'tool', toolType: 'pickaxe', tier: 2, power: 8 },\n    iron_pickaxe: { type: 'tool', toolType: 'pickaxe', tier: 3, power: 15 },\n    diamond_pickaxe: { type: 'tool', toolType: 'pickaxe', tier: 4, power: 30 }\n};<\/code><\/pre>\n\n\n\n<p><strong>\u8bbe\u8ba1\u4eae\u70b9<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>\u6bcf\u4e2a\u65b9\u5757\u5b9a\u4e49\u786c\u5ea6\u3001\u6240\u9700\u5de5\u5177\u3001\u5de5\u5177\u7b49\u7ea7<\/li><li>\u5de5\u5177\u5206\u7ea7\u7cfb\u7edf\uff08\u6728\u9550\u3001\u77f3\u9550\u3001\u94c1\u9550\u3001\u91d1\u9550\u3001\u94bb\u77f3\u9550\uff09<\/li><li>\u4e0d\u540c\u7b49\u7ea7\u7684\u5de5\u5177\u5bf9\u4e0d\u540c\u65b9\u5757\u7684\u6316\u6398\u6548\u7387\u4e0d\u540c<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u65b9\u5757\u64cd\u4f5c<\/h3>\n\n\n\n<p><strong>\u7834\u574f\u65b9\u5757<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function destroyBlock(x, y, z) {\n    const blockType = getBlock(x, y, z);\n    const item = ITEMS[blockType];\n\n    \/\/ \u68c0\u67e5\u5de5\u5177\u662f\u5426\u8db3\u591f\n    if (item.tool === 'pickaxe' &amp;&amp; currentTool.tier &lt; item.tier) {\n        appendChat(`\u9700\u8981 ${getItemNameCN(getToolName(item.tier))} \u624d\u80fd\u6316\u6398\uff01`);\n        return;\n    }\n\n    \/\/ \u79fb\u9664\u65b9\u5757\n    setBlock(x, y, z, null);\n    addBlockToInventory(blockType, 1);\n}<\/code><\/pre>\n\n\n\n<p><strong>\u653e\u7f6e\u65b9\u5757<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function placeBlock(x, y, z, blockType) {\n    if (worldBlocks.has(`${x},${y},${z}`)) {\n        appendChat('\u8fd9\u91cc\u5df2\u7ecf\u6709\u65b9\u5757\u4e86\uff01');\n        return;\n    }\n\n    \/\/ \u68c0\u67e5\u73a9\u5bb6\u4f4d\u7f6e\u662f\u5426\u88ab\u5360\u7528\n    if (x === Math.floor(camera.position.x) &amp;&amp;\n        y === Math.floor(camera.position.y) &amp;&amp;\n        z === Math.floor(camera.position.z)) {\n        appendChat('\u4e0d\u80fd\u653e\u7f6e\u5728\u73a9\u5bb6\u811a\u4e0b\uff01');\n        return;\n    }\n\n    setBlock(x, y, z, blockType);\n    removeBlockFromInventory(blockType, 1);\n}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfae \u6e38\u620f\u673a\u5236<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u751f\u5b58\u6a21\u5f0f<\/h3>\n\n\n\n<p><strong>\u751f\u547d\u503c\u4e0e\u9965\u997f\u503c<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let currentHealth = 20;  \/\/ 10\u9897\u5fc3\nlet currentHunger = 20;  \/\/ 10\u4e2a\u9e21\u817f\n\nfunction updateStatusUI() {\n    healthBarEl.innerHTML = '';\n    for(let i=0; i&lt;10; i++) {\n        healthBarEl.innerHTML += (i &lt; Math.ceil(currentHealth\/2)) ? '\u2764\ufe0f' : '\ud83d\udda4';\n    }\n}<\/code><\/pre>\n\n\n\n<p><strong>\u4f24\u5bb3\u7cfb\u7edf<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function takeDamage(amount) {\n    if (isDead || playerInvulnTimer &gt; 0 || gameMode === 0) return;\n    currentHealth -= amount;\n    updateStatusUI();\n    playerInvulnTimer = 0.5;  \/\/ 0.5\u79d2\u65e0\u654c\u65f6\u95f4\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u521b\u9020\u6a21\u5f0f<\/h3>\n\n\n\n<p><strong>\u98de\u884c\u7cfb\u7edf<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let isFlying = false;\n\n\/\/ \u53cc\u51fb\u7a7a\u683c\u952e\u98de\u884c\nif (jumpPressed &amp;&amp; !lastSpacePress) {\n    isFlying = !isFlying;\n    velocity.y = isFlying ? 0.5 : 0.2;  \/\/ \u98de\u884c\u901f\u5ea6\u66f4\u5feb\n}<\/code><\/pre>\n\n\n\n<p><strong>\u65e0\u9650\u8d44\u6e90<\/strong>\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function placeBlock(x, y, z, blockType) {\n    if (gameMode === 0) {\n        \/\/ \u521b\u9020\u6a21\u5f0f\u65e0\u9700\u6d88\u8017\u7269\u54c1\n        setBlock(x, y, z, blockType);\n        return;\n    }\n    \/\/ \u751f\u5b58\u6a21\u5f0f\u9700\u8981\u6d88\u8017\u7269\u54c1\n    \/\/ ...\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">3. \u6307\u4ee4\u7cfb\u7edf<\/h3>\n\n\n\n<p>\u6e38\u620f\u5185\u7f6e\u4e86\u4e00\u4e2a\u5f3a\u5927\u7684\u6307\u4ee4\u7cfb\u7edf\uff0c\u652f\u6301\u591a\u79cd\u529f\u80fd\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function handleCommand(cmd) {\n    const command = args[0].toLowerCase();\n\n    if (command === '\/gamemode') {\n        \/\/ \u5207\u6362\u6e38\u620f\u6a21\u5f0f\n        if (args[1] === '0') {\n            gameMode = 0;  \/\/ \u521b\u9020\u6a21\u5f0f\n        } else if (args[1] === '1') {\n            gameMode = 1;  \/\/ \u751f\u5b58\u6a21\u5f0f\n        }\n    }\n\n    else if (command === '\/give') {\n        \/\/ \u7ed9\u4e88\u7269\u54c1\n        const itemName = args[1].toLowerCase();\n        const count = args[2] ? parseInt(args[2]) : 64;\n        addBlockToInventory(itemName, count);\n    }\n\n    else if (command === '\/tp') {\n        \/\/ \u4f20\u9001\n        const x = parseFloat(args[1]);\n        const y = parseFloat(args[2]);\n        const z = parseFloat(args[3]);\n        camera.position.set(x, y, z);\n    }\n\n    else if (command === '\/heal') {\n        \/\/ \u6062\u590d\u751f\u547d\u503c\n        currentHealth = 20;\n        updateStatusUI();\n    }\n\n    else if (command === '\/feed') {\n        \/\/ \u6062\u590d\u9965\u997f\u503c\n        currentHunger = 20;\n        updateStatusUI();\n    }\n}<\/code><\/pre>\n\n\n\n<p><strong>\u53ef\u7528\u6307\u4ee4<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li><code>\/gamemode &lt;0|1&gt;<\/code> &#8211; \u5207\u6362\u6e38\u620f\u6a21\u5f0f<\/li><li><code>\/give &lt;\u7269\u54c1&gt; [\u6570\u91cf]<\/code> &#8211; \u7ed9\u4e88\u7269\u54c1<\/li><li><code>\/recipebook<\/code> &#8211; \u6253\u5f00\u5408\u6210\u914d\u65b9\u4e66<\/li><li><code>\/save<\/code> &#8211; \u6253\u5f00\u5b58\u6863\u7cfb\u7edf<\/li><li><code>\/tp &lt;x&gt; &lt;y&gt; &lt;z&gt;<\/code> &#8211; \u4f20\u9001<\/li><li><code>\/heal<\/code> &#8211; \u6062\u590d\u751f\u547d\u503c<\/li><li><code>\/feed<\/code> &#8211; \u6062\u590d\u9965\u997f\u503c<\/li><li><code>\/time<\/code> &#8211; \u663e\u793a\u6e38\u620f\u4fe1\u606f<\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\udd27 \u5408\u6210\u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. 2&#215;2 \u548c 3&#215;3 \u5408\u6210<\/h3>\n\n\n\n<p>\u6e38\u620f\u5b9e\u73b0\u4e86\u4e24\u79cd\u5408\u6210\u6a21\u5f0f\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>2&#215;2 \u5408\u6210<\/strong>\uff1a\u80cc\u5305\u5185\u76f4\u63a5\u5408\u6210<\/li><li><strong>3&#215;3 \u5408\u6210<\/strong>\uff1a\u9700\u8981\u653e\u7f6e\u5de5\u4f5c\u53f0<\/li><\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let craftingMode = 2;  \/\/ 2 = 2x2, 3 = 3x3\n\nconst recipes = [\n    { name: '\u6728\u677f', output: 'planks', count: 4, pattern: '\u4efb\u610f\u5f62\u72b6', ingredients: ['log'], mode: 2 },\n    { name: '\u6728\u9550', output: 'wooden_pickaxe', count: 1, pattern: 'T\u5f62 (3x3)', ingredients: ['planks', 'planks', 'planks', 'stick'], mode: 3 },\n    { name: '\u77f3\u9550', output: 'stone_pickaxe', count: 1, pattern: 'T\u5f62 (3x3)', ingredients: ['stone', 'stone', 'stone', 'stick'], mode: 3 }\n];<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u5408\u6210\u4e66<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function openRecipeBook() {\n    recipes.forEach(recipe =&gt; {\n        \/\/ \u663e\u793a\u6240\u6709\u914d\u65b9\n        const item = document.createElement('div');\n        item.className = 'recipe-item';\n\n        const icon = document.createElement('div');\n        icon.style.backgroundImage = `url(${icons[recipe.output]})`;\n\n        const info = document.createElement('div');\n        info.innerHTML = `\n            ${recipe.name} x${recipe.count}\n            \u914d\u65b9: ${recipe.ingredients.join(' + ')} | ${recipe.mode === 2 ? '2x2' : '3x3'}\u5408\u6210\n        `;\n    });\n}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\udcbe \u5b58\u6863\u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u4e09\u91cd\u52a0\u5bc6<\/h3>\n\n\n\n<p>\u6e38\u620f\u4f7f\u7528\u4e09\u91cd\u52a0\u5bc6\u4fdd\u62a4\u5b58\u6863\u6570\u636e\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const ENCRYPTION_KEY1 = 'MCAI_LAYER1_X1aoZhe_2024';\nconst ENCRYPTION_KEY2 = 'MCAI_LAYER2_Green_LeavesS';\nconst ENCRYPTION_KEY3 = 'MCAI_LAYER3_FINAL_SECRET';\n\nfunction encryptData(data) {\n    \/\/ \u7b2c\u4e00\u5c42\uff1aXOR + Base64\n    let layer1 = btoa(String.fromCharCode(...data.split('').map((c, i) =&gt;\n        c.charCodeAt(0) ^ ENCRYPTION_KEY1.charCodeAt(i % ENCRYPTION_KEY1.length)\n    )));\n\n    \/\/ \u7b2c\u4e8c\u5c42\uff1a\u5b57\u7b26\u4f4d\u79fb + Base64\n    let layer2 = btoa(String.fromCharCode(...layer1.split('').map(c =&gt;\n        String.fromCharCode((c.charCodeAt(0) + 7) % 256)\n    )));\n\n    \/\/ \u7b2c\u4e09\u5c42\uff1aXOR + \u53cd\u8f6c + Base64\n    let layer3 = btoa(btoa(layer2).split('').reverse().join(''));\n\n    return layer3;\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u591a\u69fd\u4f4d\u5b58\u6863<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const MAX_SLOTS = 5;\n\nfunction serializeSaveData() {\n    return {\n        version: '1.0',\n        timestamp: Date.now(),\n        gameMode: gameMode,\n        currentDimension: currentDimension,\n        playerPosition: { x, y, z },\n        inventory: {\n            hotbar: invState.hotbar,\n            main: invState.main\n        },\n        dimensions: {\n            overworld: serializeDimension('overworld'),\n            nether: serializeDimension('nether'),\n            end: serializeDimension('end')\n        }\n    };\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">3. \u5b58\u50a8\u7c7b\u578b<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u6d4f\u89c8\u5668\u5b58\u6863<\/strong>\uff1a\u4f7f\u7528 localStorage\uff0c\u9002\u5408\u5c0f\u578b\u5b58\u6863<\/li><li><strong>\u6587\u4ef6\u5b58\u6863<\/strong>\uff1a\u4f7f\u7528 Blob \u4e0b\u8f7d\uff0c\u9002\u5408\u5927\u578b\u5b58\u6863\uff0850MB+\uff09<\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfad \u5b9e\u4f53\u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u5b9e\u4f53\u6570\u636e\u7ed3\u6784<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">class Entity {\n    constructor(type, position) {\n        this.type = type;  \/\/ \u5b9e\u4f53\u7c7b\u578b\n        this.hp = 100;     \/\/ \u751f\u547d\u503c\n        this.state = 'idle';  \/\/ \u72b6\u6001\n        this.timer = 0;    \/\/ \u8ba1\u65f6\u5668\n\n        \/\/ \u521b\u5efa Three.js \u7f51\u683c\n        this.mesh = createEntityMesh(type, position);\n        scene.add(this.mesh);\n    }\n\n    update(deltaTime) {\n        \/\/ \u66f4\u65b0\u5b9e\u4f53\u72b6\u6001\n        if (this.state === 'chasing') {\n            this.chasePlayer(deltaTime);\n        }\n    }\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. Boss \u6218\u7cfb\u7edf<\/h3>\n\n\n\n<p>\u6e38\u620f\u5b9e\u73b0\u4e86\u672b\u5f71\u9f99 Boss \u6218\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">class BossEntity extends Entity {\n    constructor(position) {\n        super('ender_dragon', position);\n        this.maxHP = 100;\n        this.currentHP = 100;\n        this.attackCooldown = 0;\n    }\n\n    update(deltaTime) {\n        \/\/ AI \u903b\u8f91\n        if (this.attackCooldown &gt; 0) {\n            this.attackCooldown -= deltaTime;\n        } else {\n            this.attack();\n            this.attackCooldown = 3.0;  \/\/ 3\u79d2\u653b\u51fb\u4e00\u6b21\n        }\n\n        \/\/ \u4f20\u9001\u548c\u653b\u51fb\n        if (Math.random() &lt; 0.01) {\n            this.teleport();\n        }\n    }\n\n    attack() {\n        \/\/ \u9020\u6210\u4f24\u5bb3\n        takeDamage(2);\n        appendChat('\u26a0\ufe0f \u672b\u5f71\u9f99\u53d1\u52a8\u4e86\u653b\u51fb\uff01');\n    }\n\n    takeDamage(amount) {\n        this.currentHP -= amount;\n        updateBossBar();\n\n        if (this.currentHP &lt;= 0) {\n            this.die();\n        }\n    }\n\n    die() {\n        \/\/ Boss \u6b7b\u4ea1\u903b\u8f91\n        showWinScreen();\n    }\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">3. Boss \u8840\u6761 UI<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function updateBossBar() {\n    const bossBarFill = document.getElementById('boss-bar-fill');\n    const percentage = (bossEntity.currentHP \/ bossEntity.maxHP) * 100;\n    bossBarFill.style.width = `${percentage}%`;\n}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udf0d \u4e16\u754c\u751f\u6210<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u5730\u5f62\u751f\u6210\u7b97\u6cd5<\/h3>\n\n\n\n<p>\u4f7f\u7528 Simplex Noise \u751f\u6210\u81ea\u7136\u5730\u5f62\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">const noise2D = createNoise2D();\n\nfunction getTerrainHeight(x, z) {\n    \/\/ \u591a\u5c42\u566a\u58f0\u53e0\u52a0\n    const baseHeight = noise2D(x * 0.01, z * 0.01) * 20;\n    const detailHeight = noise2D(x * 0.05, z * 0.05) * 10;\n    const mountainHeight = noise2D(x * 0.02, z * 0.02) * 30;\n\n    return Math.floor(baseHeight + detailHeight + mountainHeight);\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u65b9\u5757\u5206\u5e03<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">function generateChunk(cx, cz) {\n    for (let x = 0; x &lt; chunkSize; x++) {\n        for (let y = 0; y &lt; chunkSize; y++) {\n            for (let z = 0; z &lt; chunkSize; z++) {\n                const worldX = cx * chunkSize + x;\n                const worldZ = cz * chunkSize + z;\n                const height = getTerrainHeight(worldX, worldZ);\n\n                \/\/ \u57fa\u5ca9\n                if (y === 0) {\n                    setBlock(worldX, y, worldZ, 'bedrock');\n                }\n                \/\/ \u5730\u9762\n                else if (y === height) {\n                    setBlock(worldX, y, worldZ, 'grass');\n                }\n                \/\/ \u6ce5\u571f\n                else if (y &gt; height - 4 &amp;&amp; y &lt; height) {\n                    setBlock(worldX, y, worldZ, 'dirt');\n                }\n                \/\/ \u77f3\u5934\u548c\u77ff\u77f3\n                else if (y &lt; height - 4) {\n                    if (Math.random() &lt; 0.05) {\n                        setBlock(worldX, y, worldZ, 'coal_ore');\n                    } else if (Math.random() &lt; 0.02) {\n                        setBlock(worldX, y, worldZ, 'iron_ore');\n                    } else {\n                        setBlock(worldX, y, worldZ, 'stone');\n                    }\n                }\n            }\n        }\n    }\n}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfa8 UI \u7cfb\u7edf<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u80cc\u5305\u4e0e\u5feb\u6377\u680f<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let invState = {\n    hotbar: Array(9).fill(null),  \/\/ 9\u4e2a\u5feb\u6377\u680f\u4f4d\n    main: Array(27).fill(null)    \/\/ 3x3\u80cc\u5305\n};\n\nfunction renderInventoryUI() {\n    const hotbarEl = document.getElementById('hotbar');\n    hotbarEl.innerHTML = '';\n\n    invState.hotbar.forEach((item, index) =&gt; {\n        const slot = document.createElement('div');\n        slot.className = 'slot';\n        slot.dataset.index = index;\n        slot.dataset.count = item ? item.count : 0;\n        slot.dataset.key = item ? item.type : '';\n        slot.style.backgroundImage = item ? `url(${icons[item.type]})` : '';\n\n        if (index === selectedSlot) {\n            slot.classList.add('active');\n        }\n\n        hotbarEl.appendChild(slot);\n    });\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u7269\u54c1\u62d6\u62fd<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let draggedItem = null;\n\nfunction onDragStart(e) {\n    const slot = e.target.closest('.slot');\n    if (slot &amp;&amp; slot.dataset.key) {\n        draggedItem = {\n            type: slot.dataset.key,\n            count: parseInt(slot.dataset.count)\n        };\n    }\n}\n\nfunction onDrop(e) {\n    const targetSlot = e.target.closest('.slot');\n    if (targetSlot &amp;&amp; draggedItem) {\n        \/\/ \u4ea4\u6362\u7269\u54c1\n        const sourceSlot = document.querySelector('.slot[draggable=\"true\"]');\n        const tempItem = sourceSlot.dataset.key ? {\n            type: sourceSlot.dataset.key,\n            count: parseInt(sourceSlot.dataset.count)\n        } : null;\n\n        sourceSlot.dataset.key = draggedItem.type;\n        sourceSlot.dataset.count = draggedItem.count;\n        sourceSlot.style.backgroundImage = draggedItem.type ? `url(${icons[draggedItem.type]})` : '';\n\n        targetSlot.dataset.key = tempItem ? tempItem.type : '';\n        targetSlot.dataset.count = tempItem ? tempItem.count : 0;\n        targetSlot.style.backgroundImage = tempItem ? `url(${icons[tempItem.type]})` : '';\n\n        draggedItem = null;\n    }\n}<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\ude80 \u6e38\u620f\u5faa\u73af<\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"javascript\">let lastTime = performance.now();\nlet frameCount = 0;\nlet lastFpsUpdate = 0;\n\nfunction animate() {\n    requestAnimationFrame(animate);\n\n    const now = performance.now();\n    const deltaTime = (now - lastTime) \/ 1000;\n    lastTime = now;\n\n    \/\/ FPS \u8ba1\u7b97\n    frameCount++;\n    if (now - lastFpsUpdate &gt;= 1000) {\n        const fps = Math.round(frameCount \/ ((now - lastFpsUpdate) \/ 1000));\n        document.getElementById('fps-display').textContent = `FPS: ${fps}`;\n        frameCount = 0;\n        lastFpsUpdate = now;\n    }\n\n    \/\/ \u66f4\u65b0\u8c03\u8bd5\u4fe1\u606f\n    updateDebugUI();\n\n    \/\/ \u66f4\u65b0\u5b9e\u4f53\n    entities.forEach(entity =&gt; entity.update(deltaTime));\n\n    \/\/ \u66f4\u65b0 Boss \u8840\u6761\n    updateBossBar();\n\n    \/\/ \u6e32\u67d3\n    renderer.render(scene, camera);\n}\n\nanimate();<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\udcca \u6027\u80fd\u5206\u6790<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u65f6\u95f4\u590d\u6742\u5ea6<\/h3>\n\n\n\n<figure class=\"wp-block-table\"><table><thead><tr><th>\u64cd\u4f5c<\/th><th>\u590d\u6742\u5ea6<\/th><th>\u8bf4\u660e<\/th><\/tr><\/thead><tbody><tr><td>\u83b7\u53d6\u65b9\u5757<\/td><td>O(1)<\/td><td>\u4f7f\u7528 Map \u5feb\u901f\u67e5\u627e<\/td><\/tr><tr><td>\u7834\u574f\u65b9\u5757<\/td><td>O(log n)<\/td><td>\u533a\u5757\u7f51\u683c\u91cd\u5efa<\/td><\/tr><tr><td>\u653e\u7f6e\u65b9\u5757<\/td><td>O(log n)<\/td><td>\u533a\u5757\u7f51\u683c\u91cd\u5efa<\/td><\/tr><tr><td>\u5408\u6210<\/td><td>O(1)<\/td><td>\u54c8\u5e0c\u67e5\u627e\u914d\u65b9<\/td><\/tr><tr><td>\u4f20\u9001<\/td><td>O(1)<\/td><td>\u76f4\u63a5\u8bbe\u7f6e\u4f4d\u7f6e<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">\u7a7a\u95f4\u590d\u6742\u5ea6<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u533a\u5757\u6570\u636e<\/strong>\uff1aO(\u533a\u5757\u6570\u91cf \u00d7 16 \u00d7 16 \u00d7 4) = O(\u533a\u5757\u6570\u91cf)<\/li><li><strong>\u7eb9\u7406<\/strong>\uff1aO(\u65b9\u5757\u7c7b\u578b) \u2248 O(30)<\/li><li><strong>UI \u5143\u7d20<\/strong>\uff1aO(\u5e38\u91cf)<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">\u4f18\u5316\u6280\u5de7<\/h3>\n\n\n\n<ol class=\"wp-block-list\"><li><strong>\u89c6\u9525\u4f53\u5254\u9664<\/strong>\uff1a\u53ea\u6e32\u67d3\u76f8\u673a\u89c6\u91ce\u5185\u7684\u533a\u5757<\/li><li><strong>LOD \u7cfb\u7edf<\/strong>\uff1a\u6839\u636e\u8ddd\u79bb\u8c03\u6574\u6e32\u67d3\u7ec6\u8282<\/li><li><strong>\u5ef6\u8fdf\u7f51\u683c\u91cd\u5efa<\/strong>\uff1a\u6279\u91cf\u5904\u7406\u65b9\u5757\u4fee\u6539<\/li><li><strong>\u5b9e\u4f53\u7a7a\u95f4\u5206\u533a<\/strong>\uff1a\u52a0\u901f\u78b0\u649e\u68c0\u6d4b<\/li><li><strong>\u50cf\u7d20\u6bd4\u9650\u5236<\/strong>\uff1a<code>Math.min(devicePixelRatio, 2)<\/code> \u9632\u6b62\u79fb\u52a8\u7aef\u8fc7\u8f7d<\/li><\/ol>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83c\udfaf \u4eae\u70b9\u603b\u7ed3<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u6280\u672f\u521b\u65b0<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u7eaf\u524d\u7aef\u5b9e\u73b0<\/strong>\uff1a\u65e0\u9700\u540e\u7aef\uff0c\u6d4f\u89c8\u5668\u5373\u53ef\u8fd0\u884c<\/li><li><strong>\u52a8\u6001\u7eb9\u7406<\/strong>\uff1aCanvas API \u5b9e\u65f6\u751f\u6210\u50cf\u7d20\u7eb9\u7406<\/li><li><strong>\u4e09\u91cd\u52a0\u5bc6\u5b58\u6863<\/strong>\uff1a\u591a\u5c42\u52a0\u5bc6\u4fdd\u62a4\u73a9\u5bb6\u8fdb\u5ea6<\/li><li><strong>\u591a\u7ef4\u5ea6\u7cfb\u7edf<\/strong>\uff1a\u4e3b\u4e16\u754c\u3001\u4e0b\u754c\u3001\u672b\u5730\u72ec\u7acb\u6570\u636e<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u6e38\u620f\u8bbe\u8ba1<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u751f\u5b58\/\u521b\u9020\u6a21\u5f0f<\/strong>\uff1a\u4e24\u79cd\u4e0d\u540c\u7684\u6e38\u620f\u4f53\u9a8c<\/li><li><strong>\u5b8c\u6574\u5408\u6210\u7cfb\u7edf<\/strong>\uff1a2&#215;2 \u548c 3&#215;3 \u5408\u6210<\/li><li><strong>Boss \u6218\u7cfb\u7edf<\/strong>\uff1a\u672b\u5f71\u9f99\u6218\u6597<\/li><li><strong>\u591a\u69fd\u4f4d\u5b58\u6863<\/strong>\uff1a5\u4e2a\u5b58\u6863\u69fd\u4f4d<\/li><\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">3. \u7528\u6237\u4f53\u9a8c<\/h3>\n\n\n\n<ul class=\"wp-block-list\"><li><strong>\u6307\u4ee4\u7cfb\u7edf<\/strong>\uff1a\u5f3a\u5927\u7684 <code>\/give<\/code>\u3001<code>\/tp<\/code> \u7b49\u6307\u4ee4<\/li><li><strong>\u5408\u6210\u4e66<\/strong>\uff1a\u67e5\u770b\u6240\u6709\u914d\u65b9\u548c\u7269\u54c1<\/li><li><strong>\u5b58\u6863\u7f16\u8f91\u5668<\/strong>\uff1a\u5bfc\u51fa\/\u5bfc\u5165\u5b58\u6863<\/li><li><strong>\u8c03\u8bd5\u4fe1\u606f<\/strong>\uff1aFPS\u3001\u5750\u6807\u3001\u751f\u7269\u7fa4\u7cfb<\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\udee0\ufe0f \u5f00\u53d1\u5efa\u8bae<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u6027\u80fd\u4f18\u5316<\/h3>\n\n\n\n<ol class=\"wp-block-list\"><li><strong>\u5b9e\u4f8b\u5316\u6e32\u67d3<\/strong>\uff1a\u4f7f\u7528 <code>THREE.InstancedMesh<\/code> \u6e32\u67d3\u5927\u91cf\u76f8\u540c\u65b9\u5757<\/li><li><strong>\u7a0b\u5e8f\u5316\u7eb9\u7406<\/strong>\uff1a\u4f7f\u7528 WebGL \u7740\u8272\u5668\u751f\u6210\u7eb9\u7406<\/li><li><strong>Web Worker<\/strong>\uff1a\u5c06\u533a\u5757\u751f\u6210\u79fb\u5230 Worker \u7ebf\u7a0b<\/li><li><strong>WebGL 2.0<\/strong>\uff1a\u4f7f\u7528\u66f4\u9ad8\u6548\u7684\u6e32\u67d3\u7ba1\u7ebf<\/li><\/ol>\n\n\n\n<h3 class=\"wp-block-heading\">\u529f\u80fd\u6269\u5c55<\/h3>\n\n\n\n<ol class=\"wp-block-list\"><li><strong>\u591a\u4eba\u6e38\u620f<\/strong>\uff1a\u4f7f\u7528 WebSocket \u5b9e\u73b0\u8054\u673a<\/li><li><strong>\u7269\u7406\u5f15\u64ce<\/strong>\uff1a\u96c6\u6210 Cannon.js \u6216 Ammo.js<\/li><li><strong>\u97f3\u9891\u7cfb\u7edf<\/strong>\uff1a\u4f7f\u7528 Web Audio API \u751f\u6210\u97f3\u6548<\/li><li><strong>\u6210\u5c31\u7cfb\u7edf<\/strong>\uff1a\u6dfb\u52a0\u6210\u5c31\u89e3\u9501\u673a\u5236<\/li><\/ol>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\ud83d\udcda \u6280\u672f\u53c2\u8003<\/h2>\n\n\n\n<ul class=\"wp-block-list\"><li><a href=\"https:\/\/threejs.org\/docs\/\">Three.js \u5b98\u65b9\u6587\u6863<\/a><\/li><li><a href=\"https:\/\/github.com\/jwagner\/simplex-noise.js\">Simplex Noise \u7b97\u6cd5<\/a><\/li><li><a href=\"https:\/\/github.com\/mrdoob\/three.js\/tree\/dev\/examples\/jsm\/controls\/PointerLockControls.js\">PointerLockControls<\/a><\/li><li><a href=\"https:\/\/minecraft.fandom.com\/\">Minecraft Wiki<\/a><\/li><\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<p><strong>\u5f00\u53d1\u8005<\/strong>\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>Green_LeavesS &#8211; \u6838\u5fc3\u67b6\u6784 \/ \u6e32\u67d3\u5f15\u64ce<\/li><li>SJL &#8211; \u6e38\u620f\u5f00\u53d1\u4e0e\u6d4b\u8bd5<\/li><li>X1aoZhe &#8211; \u6e38\u620f\u8bbe\u8ba1\u4e0e\u4f18\u5316<\/li><\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u6280\u672f\u89e3\u6790\uff1aX1aoZhe \u7684\u50cf\u7d20\u4e16\u754c &#8211; \u7ec8\u5c40\u4e4b\u6218 \ud83c\udfaf \u9879\u76ee\u6982\u8ff0 \u300a\u50cf\u7d20\u4e16\u754c &#8211; \u7ec8\u5c40 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[100,94],"tags":[101,98,103,104,102],"class_list":["post-86","post","type-post","status-publish","format-standard","hentry","category-100","category-94","tag-javascript","tag-three-js","tag-web","tag-104","tag-102"],"_links":{"self":[{"href":"https:\/\/www.sjll.top\/index.php?rest_route=\/wp\/v2\/posts\/86","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.sjll.top\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.sjll.top\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.sjll.top\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.sjll.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=86"}],"version-history":[{"count":0,"href":"https:\/\/www.sjll.top\/index.php?rest_route=\/wp\/v2\/posts\/86\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.sjll.top\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=86"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.sjll.top\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=86"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.sjll.top\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=86"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}