{"id":26008,"date":"2025-05-12T19:25:52","date_gmt":"2025-05-12T10:25:52","guid":{"rendered":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26008"},"modified":"2025-05-12T19:25:54","modified_gmt":"2025-05-12T10:25:54","slug":"%e3%82%b2%e3%83%bc%e3%83%a0bgm%e8%87%aa%e5%8b%95%e7%94%9f%e6%88%90%e3%82%b5%e3%83%bc%e3%83%93%e3%82%b9-html","status":"publish","type":"post","link":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26008","title":{"rendered":"\u30b2\u30fc\u30e0BGM\u81ea\u52d5\u751f\u6210\u30b5\u30fc\u30d3\u30b9.html"},"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>\ud83c\udfae \u30b2\u30fc\u30e0BGM\u81ea\u52d5\u751f\u6210\u30b5\u30fc\u30d3\u30b9&lt;\/title>\n  &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n  &lt;style>\n    :root {\n      --bg: #121212;\n      --card: #1e1e2e;\n      --text: #ffffff;\n      --accent: #ffd700;\n      --shadow: rgba(0, 0, 0, 0.3);\n      --button: #ffd700;\n    }\n    &#91;data-theme='light'] {\n      --bg: #f5f5f5;\n      --card: #ffffff;\n      --text: #111;\n      --accent: #ff9800;\n      --shadow: rgba(0, 0, 0, 0.1);\n      --button: #ff9800;\n    }\n\n    body {\n      margin: 0;\n      font-family: 'Segoe UI', sans-serif;\n      background: var(--bg);\n      color: var(--text);\n      transition: 0.3s;\n      padding: 1rem;\n    }\n\n    header {\n      text-align: center;\n      margin-bottom: 1rem;\n    }\n\n    h1 {\n      color: var(--accent);\n      font-size: 2rem;\n    }\n\n    .container {\n      max-width: 600px;\n      margin: auto;\n      background: var(--card);\n      border-radius: 12px;\n      box-shadow: 0 0 10px var(--shadow);\n      padding: 1.5rem;\n    }\n\n    label {\n      font-weight: bold;\n      display: block;\n      margin-top: 1rem;\n    }\n\n    select, button {\n      width: 100%;\n      padding: 0.6rem;\n      margin-top: 0.5rem;\n      border-radius: 8px;\n      border: none;\n      font-size: 1rem;\n    }\n\n    button {\n      background: var(--button);\n      color: #000;\n      font-weight: bold;\n      cursor: pointer;\n      transition: 0.3s;\n    }\n\n    button:disabled {\n      background: #999;\n      cursor: not-allowed;\n    }\n\n    button:hover:enabled {\n      opacity: 0.85;\n    }\n\n    .desc, .msg {\n      margin-top: 1rem;\n      font-size: 0.9rem;\n      color: #ccc;\n    }\n\n    .result, .history {\n      margin-top: 2rem;\n    }\n\n    audio {\n      width: 100%;\n      margin-top: 0.5rem;\n    }\n\n    .visualizer {\n      width: 100%;\n      height: 4px;\n      background: linear-gradient(90deg, #ffd700, #ff9800);\n      animation: pulse 2s infinite linear;\n      opacity: 0;\n    }\n\n    .playing .visualizer {\n      opacity: 1;\n    }\n\n    @keyframes pulse {\n      0% { transform: scaleX(1); }\n      50% { transform: scaleX(1.05); }\n      100% { transform: scaleX(1); }\n    }\n\n    .toggle-theme {\n      text-align: right;\n      margin-bottom: 0.5rem;\n    }\n\n    .accordion {\n      background: transparent;\n      color: var(--accent);\n      border: none;\n      font-weight: bold;\n      cursor: pointer;\n      margin-top: 1rem;\n      width: 100%;\n      text-align: left;\n      font-size: 1rem;\n    }\n\n    .accordion-content {\n      max-height: 0;\n      overflow: hidden;\n      transition: max-height 0.3s ease;\n    }\n\n    .accordion.open + .accordion-content {\n      max-height: 600px;\n    }\n  &lt;\/style>\n&lt;\/head>\n&lt;body>\n\n  &lt;header>\n    &lt;h1>\ud83c\udfae \u30b2\u30fc\u30e0BGM\u81ea\u52d5\u751f\u6210&lt;\/h1>\n  &lt;\/header>\n\n  &lt;div class=\"toggle-theme\">\n    &lt;button onclick=\"toggleTheme()\">\ud83c\udf13 \u30c6\u30fc\u30de\u5207\u66ff&lt;\/button>\n  &lt;\/div>\n\n  &lt;div class=\"container\">\n    &lt;label for=\"genre\">\ud83c\udfbc \u30b8\u30e3\u30f3\u30eb&lt;\/label>\n    &lt;select id=\"genre\" onchange=\"updateDescription()\">\n      &lt;option value=\"fantasy\">\u30d5\u30a1\u30f3\u30bf\u30b8\u30fc&lt;\/option>\n      &lt;option value=\"cyberpunk\">\u30b5\u30a4\u30d0\u30fc\u30d1\u30f3\u30af&lt;\/option>\n      &lt;option value=\"horror\">\u30db\u30e9\u30fc&lt;\/option>\n      &lt;option value=\"symphonic\">\u30b7\u30f3\u30d5\u30a9\u30cb\u30c3\u30af&lt;\/option>\n    &lt;\/select>\n\n    &lt;label for=\"mood\">\ud83c\udfad \u96f0\u56f2\u6c17&lt;\/label>\n    &lt;select id=\"mood\" onchange=\"updateDescription()\">\n      &lt;option value=\"mysterious\">\u795e\u79d8\u7684&lt;\/option>\n      &lt;option value=\"sad\">\u60b2\u3057\u3044&lt;\/option>\n      &lt;option value=\"heroic\">\u52c7\u307e\u3057\u3044&lt;\/option>\n      &lt;option value=\"fun\">\u697d\u3057\u3044&lt;\/option>\n    &lt;\/select>\n\n    &lt;div class=\"desc\" id=\"descText\">\u9078\u629e\u5185\u5bb9\u306b\u5fdc\u3058\u3066BGM\u3092\u751f\u6210\u3057\u307e\u3059\u3002&lt;\/div>\n\n    &lt;button id=\"generateBtn\" onclick=\"generateBGM()\">\ud83c\udfb6 BGM\u3092\u751f\u6210\u3059\u308b&lt;\/button>\n\n    &lt;div class=\"msg\" id=\"msg\">&lt;\/div>\n\n    &lt;div class=\"result\" id=\"result\" style=\"display:none;\">\n      &lt;h3>\ud83c\udfa7 \u518d\u751f\u4e2d\u306eBGM&lt;\/h3>\n      &lt;audio controls id=\"player\" onplay=\"startVisualizer()\" onpause=\"stopVisualizer()\">&lt;\/audio>\n      &lt;div class=\"visualizer\" id=\"visualizer\">&lt;\/div>\n    &lt;\/div>\n\n    &lt;button class=\"accordion\" onclick=\"toggleAccordion(this)\">\ud83d\udcdc \u518d\u751f\u5c65\u6b74&lt;\/button>\n    &lt;div class=\"accordion-content\" id=\"historyList\">&lt;\/div>\n  &lt;\/div>\n\n  &lt;script>\n    const descMap = {\n      fantasy: \"\u9b54\u6cd5\u306e\u4e16\u754c\u3001\u5192\u967a\u3068\u4f1d\u8aac\u306e\u97f3\u697d\",\n      cyberpunk: \"\u8fd1\u672a\u6765\u90fd\u5e02\u3068\u30c6\u30af\u30ce\u611f\u306e\u878d\u5408\",\n      horror: \"\u4e0d\u5b89\u3068\u6050\u6016\u3092\u717d\u308bBGM\",\n      symphonic: \"\u58ee\u5927\u3067\u611f\u52d5\u7684\u306a\u30aa\u30fc\u30b1\u30b9\u30c8\u30e9\u98a8\",\n      mysterious: \"\u8b0e\u89e3\u304d\u3001\u63a2\u691c\u306b\u3074\u3063\u305f\u308a\",\n      sad: \"\u6d99\u3084\u55aa\u5931\u611f\u3092\u8868\u73fe\u3059\u308b\u65cb\u5f8b\",\n      heroic: \"\u52c7\u307e\u3057\u3055\u3001\u6226\u3044\u3001\u52dd\u5229\u306e\u8c61\u5fb4\",\n      fun: \"\u8efd\u5feb\u3067\u660e\u308b\u3044\u30ea\u30ba\u30e0\"\n    };\n\n    const history = &#91;];\n    const maxHistory = 5;\n\n    function updateDescription() {\n      const g = document.getElementById('genre').value;\n      const m = document.getElementById('mood').value;\n      document.getElementById('descText').textContent = `\ud83e\udde0 ${descMap&#91;g]} \u00d7 ${descMap&#91;m]}`;\n    }\n\n    function generateBGM() {\n      const genre = document.getElementById('genre').value;\n      const mood = document.getElementById('mood').value;\n      const btn = document.getElementById('generateBtn');\n      const player = document.getElementById('player');\n      const msg = document.getElementById('msg');\n      const result = document.getElementById('result');\n\n      btn.disabled = true;\n      msg.textContent = \"\u23f3 BGM\u3092\u751f\u6210\u4e2d...\";\n\n      const url = `https:\/\/example.com\/bgm\/${genre}_${mood}_${Math.floor(Math.random()*3)+1}.mp3`;\n\n      setTimeout(() => {\n        msg.textContent = \"\u2705 BGM\u751f\u6210\u5b8c\u4e86\uff01\u518d\u751f\u3067\u304d\u307e\u3059\u3002\";\n        player.src = url;\n        result.style.display = 'block';\n\n        \/\/ \u4fdd\u5b58\u5c65\u6b74\n        history.unshift({ genre, mood, url });\n        if (history.length > maxHistory) history.pop();\n        renderHistory();\n        btn.disabled = false;\n      }, 1500);\n    }\n\n    function renderHistory() {\n      const list = document.getElementById('historyList');\n      list.innerHTML = \"\";\n      history.forEach(item => {\n        const div = document.createElement('div');\n        div.innerHTML = `&lt;strong>${item.genre} \u00d7 ${item.mood}&lt;\/strong>&lt;br>&lt;audio controls src=\"${item.url}\">&lt;\/audio>&lt;hr>`;\n        list.appendChild(div);\n      });\n    }\n\n    function toggleTheme() {\n      const theme = document.documentElement.getAttribute(\"data-theme\");\n      document.documentElement.setAttribute(\"data-theme\", theme === \"light\" ? \"dark\" : \"light\");\n    }\n\n    function toggleAccordion(el) {\n      el.classList.toggle('open');\n    }\n\n    function startVisualizer() {\n      document.getElementById('visualizer').style.opacity = '1';\n    }\n\n    function stopVisualizer() {\n      document.getElementById('visualizer').style.opacity = '0';\n    }\n\n    \/\/ \u521d\u671f\u8a2d\u5b9a\n    document.documentElement.setAttribute(\"data-theme\", \"dark\");\n    updateDescription();\n  &lt;\/script>\n\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":[80,87,96],"tags":[3],"class_list":{"0":"post-26008","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"hentry","6":"category-html","7":"category-web","9":"tag-programming"},"aioseo_notices":[],"jetpack_featured_media_url":"","_links":{"self":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26008","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=26008"}],"version-history":[{"count":1,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26008\/revisions"}],"predecessor-version":[{"id":26009,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26008\/revisions\/26009"}],"wp:attachment":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=26008"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=26008"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=26008"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}