{"id":26015,"date":"2025-05-16T16:13:10","date_gmt":"2025-05-16T07:13:10","guid":{"rendered":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26015"},"modified":"2025-05-16T16:13:11","modified_gmt":"2025-05-16T07:13:11","slug":"trpg%e3%82%b7%e3%83%8a%e3%83%aa%e3%82%aa%e8%87%aa%e5%8b%95%e7%94%9f%e6%88%90%ef%bc%86%e5%85%b1%e6%9c%89","status":"publish","type":"post","link":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26015","title":{"rendered":"TRPG\u30b7\u30ca\u30ea\u30aa\u81ea\u52d5\u751f\u6210\uff06\u5171\u6709"},"content":{"rendered":"\n<pre class=\"wp-block-code\"><code>&lt;!DOCTYPE html>\n&lt;html lang=\"ja\">\n&lt;head>\n  &lt;meta charset=\"UTF-8\">\n  &lt;title>TRPG\u30b7\u30ca\u30ea\u30aa\u81ea\u52d5\u751f\u6210\uff06\u5171\u6709&lt;\/title>\n  &lt;style>\n    body {\n      font-family: 'Segoe UI', sans-serif;\n      background: #f4f4f4;\n      padding: 20px;\n      max-width: 800px;\n      margin: auto;\n    }\n    h1, h2 {\n      text-align: center;\n    }\n    select, button, textarea {\n      width: 100%;\n      padding: 10px;\n      margin-top: 10px;\n      font-size: 1rem;\n    }\n    .box {\n      background: #fff;\n      padding: 15px;\n      border-radius: 8px;\n      margin-top: 20px;\n      box-shadow: 0 2px 4px rgba(0,0,0,0.1);\n    }\n    .scenario {\n      background: #f9f9f9;\n      border-left: 5px solid #4CAF50;\n      margin-bottom: 10px;\n      padding: 10px;\n      border-radius: 5px;\n      position: relative;\n    }\n    .btns {\n      margin-top: 10px;\n      display: flex;\n      gap: 10px;\n    }\n    .copy, .save, .delete {\n      cursor: pointer;\n      border: none;\n      padding: 8px 12px;\n      border-radius: 4px;\n    }\n    .copy { background: #2196F3; color: white; }\n    .save { background: #4CAF50; color: white; }\n    .delete { background: #f44336; color: white; }\n  &lt;\/style>\n&lt;\/head>\n&lt;body>\n  &lt;h1>\ud83c\udfb2 TRPG\u30b7\u30ca\u30ea\u30aa\u81ea\u52d5\u751f\u6210\u30b5\u30a4\u30c8&lt;\/h1>\n\n  &lt;div class=\"box\">\n    &lt;label>\u30b8\u30e3\u30f3\u30eb\u9078\u629e:&lt;\/label>\n    &lt;select id=\"genre\">\n      &lt;option value=\"fantasy\">\u30d5\u30a1\u30f3\u30bf\u30b8\u30fc&lt;\/option>\n      &lt;option value=\"horror\">\u30db\u30e9\u30fc&lt;\/option>\n      &lt;option value=\"scifi\">SF&lt;\/option>\n    &lt;\/select>\n    &lt;button onclick=\"generateScenario()\">\ud83d\udcdc \u30b7\u30ca\u30ea\u30aa\u3092\u751f\u6210\u3059\u308b&lt;\/button>\n  &lt;\/div>\n\n  &lt;div id=\"scenarioBox\" class=\"box\">&lt;\/div>\n\n  &lt;h2>\ud83d\uddc3 \u4fdd\u5b58\u6e08\u307f\u30b7\u30ca\u30ea\u30aa&lt;\/h2>\n  &lt;div id=\"savedScenarios\" class=\"box\">&lt;\/div>\n\n  &lt;script>\n    const data = {\n      fantasy: {\n        title: &#91;\"\u5c01\u5370\u306e\u8ff7\u5bae\", \"\u8056\u9a0e\u58eb\u306e\u8a66\u7df4\", \"\u9b54\u738b\u5fa9\u6d3b\u306e\u4e88\u5146\", \"\u5931\u308f\u308c\u305f\u738b\u56fd\"],\n        world: &#91;\"\u4e2d\u4e16\u306e\u738b\u56fd\", \"\u53e4\u4ee3\u306e\u795e\u6bbf\", \"\u5929\u7a7a\u90fd\u5e02\", \"\u30a8\u30eb\u30d5\u306e\u68ee\"],\n        incident: &#91;\"\u9b54\u6cd5\u306e\u66b4\u8d70\", \"\u4f1d\u8aac\u306e\u5263\u306e\u767a\u898b\", \"\u7cbe\u970a\u306e\u7570\u5909\", \"\u7adc\u306e\u8972\u6483\"],\n        npc: &#91;\"\u82e5\u304d\u9b54\u5c0e\u58eb\", \"\u5fe0\u7fa9\u306e\u9a0e\u58eb\", \"\u96a0\u8005\u306e\u8ce2\u8005\", \"\u88cf\u5207\u308a\u8005\u306e\u5deb\u5973\"],\n        goal: &#91;\"\u771f\u5b9f\u3092\u89e3\u660e\u305b\u3088\", \"\u5c01\u5370\u3092\u5f37\u5316\u305b\u3088\", \"\u5100\u5f0f\u3092\u963b\u6b62\u305b\u3088\", \"\u907a\u8de1\u306e\u8b0e\u3092\u89e3\u3051\"]\n      },\n      horror: {\n        title: &#91;\"\u546a\u308f\u308c\u305f\u6751\", \"\u6df1\u591c\u306e\u5ec3\u75c5\u9662\", \"\u5c01\u5370\u3055\u308c\u305f\u30d3\u30c7\u30aa\", \"\u8840\u5857\u3089\u308c\u305f\u5100\u5f0f\"],\n        world: &#91;\"\u96e8\u306e\u5c71\u5965\", \"\u9589\u9396\u3055\u308c\u305f\u75c5\u9662\", \"\u5730\u4e0b\u306e\u5100\u5f0f\u5834\", \"\u5fd8\u308c\u53bb\u3089\u308c\u305f\u6d0b\u9928\"],\n        incident: &#91;\"\u7a81\u7136\u306e\u5931\u8e2a\u4e8b\u4ef6\", \"\u898b\u3048\u306a\u3044\u4f55\u304b\u306e\u5f71\", \"\u4e0d\u6c17\u5473\u306a\u624b\u7d19\", \"\u93e1\u306e\u4e2d\u306e\u8ab0\u304b\"],\n        npc: &#91;\"\u7cbe\u795e\u3092\u75c5\u3093\u3060\u795e\u7236\", \"\u8b66\u5bdf\u5b98\u306e\u5e7d\u970a\", \"\u8a9e\u3089\u306c\u8001\u5a46\", \"\u9996\u306e\u306a\u3044\u5c11\u5973\"],\n        goal: &#91;\"\u8131\u51fa\u305b\u3088\", \"\u8b0e\u3092\u66b4\u3051\", \"\u546a\u3044\u3092\u89e3\u3051\", \"\u5100\u5f0f\u3092\u6b62\u3081\u308d\"]\n      },\n      scifi: {\n        title: &#91;\"\u661f\u9593\u6226\u4e89\u306e\u706b\u7a2e\", \"\u6a5f\u68b0\u53cd\u4e71\u306e\u591c\", \"\u6d88\u3048\u305f\u5b87\u5b99\u8239\", \"\u8a18\u61b6\u3092\u5931\u3063\u305f\u5730\u7403\"],\n        world: &#91;\"\u5b87\u5b99\u30b3\u30ed\u30cb\u30fc\", \"\u6708\u9762\u90fd\u5e02\", \"\u7570\u661f\u306e\u907a\u8de1\", \"\u30b5\u30a4\u30d0\u30fc\u30d1\u30f3\u30af\u90fd\u5e02\"],\n        incident: &#91;\"AI\u306e\u66b4\u8d70\", \"\u91cd\u529b\u7570\u5e38\", \"\u901a\u4fe1\u65ad\u7d76\", \"\u30c6\u30ec\u30dd\u30fc\u30c8\u4e8b\u6545\"],\n        npc: &#91;\"\u30b5\u30a4\u30dc\u30fc\u30b0\u5175\u58eb\", \"\u8a18\u61b6\u3092\u5931\u3063\u305f\u535a\u58eb\", \"\u4f01\u696d\u30b9\u30d1\u30a4\", \"\u7570\u661f\u306e\u5b50\u4f9b\"],\n        goal: &#91;\"\u539f\u56e0\u3092\u7a76\u660e\u305b\u3088\", \"AI\u3092\u505c\u6b62\u305b\u3088\", \"\u4eba\u985e\u3092\u6551\u3048\", \"\u771f\u5b9f\u3092\u66b4\u3051\"]\n      }\n    };\n\n    function generateScenario() {\n      const genre = document.getElementById(\"genre\").value;\n      const g = data&#91;genre];\n\n      const title = rand(g.title);\n      const world = rand(g.world);\n      const incident = rand(g.incident);\n      const npc = rand(g.npc);\n      const goal = rand(g.goal);\n\n      const scenarioText = `\u3010\u30bf\u30a4\u30c8\u30eb\u3011${title}\\n\u3010\u821e\u53f0\u3011${world}\\n\u3010\u4e8b\u4ef6\u3011${incident}\\n\u3010NPC\u3011${npc}\\n\u3010\u76ee\u7684\u3011${goal}`;\n      const html = `\n        &lt;div class=\"scenario\">\n          &lt;pre>${scenarioText}&lt;\/pre>\n          &lt;div class=\"btns\">\n            &lt;button class=\"copy\" onclick=\"copyText(\\`${scenarioText.replace(\/`\/g, '\\\\`')}\\`)\">\ud83d\udccb \u30b3\u30d4\u30fc&lt;\/button>\n            &lt;button class=\"save\" onclick=\"saveScenario(\\`${scenarioText.replace(\/`\/g, '\\\\`')}\\`)\">\ud83d\udcbe \u4fdd\u5b58&lt;\/button>\n          &lt;\/div>\n        &lt;\/div>\n      `;\n      document.getElementById(\"scenarioBox\").innerHTML = html;\n    }\n\n    function rand(arr) {\n      return arr&#91;Math.floor(Math.random() * arr.length)];\n    }\n\n    function copyText(text) {\n      navigator.clipboard.writeText(text).then(() => {\n        alert(\"\u30b3\u30d4\u30fc\u3057\u307e\u3057\u305f\uff01\");\n      });\n    }\n\n    function saveScenario(text) {\n      let saved = JSON.parse(localStorage.getItem(\"trpgScenarios\") || \"&#91;]\");\n      saved.push(text);\n      localStorage.setItem(\"trpgScenarios\", JSON.stringify(saved));\n      alert(\"\u4fdd\u5b58\u3057\u307e\u3057\u305f\uff01\");\n      showSaved();\n    }\n\n    function deleteScenario(index) {\n      let saved = JSON.parse(localStorage.getItem(\"trpgScenarios\") || \"&#91;]\");\n      saved.splice(index, 1);\n      localStorage.setItem(\"trpgScenarios\", JSON.stringify(saved));\n      showSaved();\n    }\n\n    function showSaved() {\n      const box = document.getElementById(\"savedScenarios\");\n      const saved = JSON.parse(localStorage.getItem(\"trpgScenarios\") || \"&#91;]\");\n      if (saved.length === 0) {\n        box.innerHTML = \"&lt;p>\u4fdd\u5b58\u3055\u308c\u3066\u3044\u308b\u30b7\u30ca\u30ea\u30aa\u306f\u3042\u308a\u307e\u305b\u3093\u3002&lt;\/p>\";\n        return;\n      }\n      box.innerHTML = saved.map((s, i) => `\n        &lt;div class=\"scenario\">\n          &lt;pre>${s}&lt;\/pre>\n          &lt;div class=\"btns\">\n            &lt;button class=\"copy\" onclick=\"copyText(\\`${s.replace(\/`\/g, '\\\\`')}\\`)\">\ud83d\udccb \u30b3\u30d4\u30fc&lt;\/button>\n            &lt;button class=\"delete\" onclick=\"deleteScenario(${i})\">\ud83d\uddd1 \u524a\u9664&lt;\/button>\n          &lt;\/div>\n        &lt;\/div>\n      `).join(\"\");\n    }\n\n    \/\/ \u521d\u56de\u30ed\u30fc\u30c9\n    showSaved();\n  &lt;\/script>\n&lt;\/body>\n&lt;\/html>\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"_uf_show_specific_survey":0,"_uf_disable_surveys":false,"footnotes":""},"categories":[4,6,73],"tags":[],"class_list":["post-26015","post","type-post","status-publish","format-standard","hentry","category-programming","category-web","category-73"],"aioseo_notices":[],"jetpack_featured_media_url":"","_links":{"self":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26015","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=26015"}],"version-history":[{"count":1,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26015\/revisions"}],"predecessor-version":[{"id":26016,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26015\/revisions\/26016"}],"wp:attachment":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=26015"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=26015"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=26015"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}