大和魂
2024/07/03

飽きてきた背景

変わり映えしない背景

どうも、The Infinity’sです。つい最近自分のサイトをみていて、思うことがあるのです。
「なんか背景が変わり映えしないな…」
と。なので今回作ってみることにしました。

蜂蜜牛乳

考えとしては…ある日、Scratchの@honey-milk1さんに
「伝統的な模様を作ってみてはどうか」(記憶が曖昧)
と言われて、作ろうと思ってたのですが、Scratchでつくろうにもキツかったのと、
つい最近まで他の人のサイト制作の手伝いや、日頃の業務が忙しかったので、
作る気が失せていたのですが、ひと段落したので、つくろうと思います。

いつもの

JavaScriptで作ります。理由は簡単なのと動作が速いからです。
ソースは私٩( ᐛ )و

変更前

const init_header = function () {
  //headerの初期化
  const header_text = `
    <a href="/" aria-label="Home">
      <img id="headerLogo" class="The-Infinitys" src="/image/The-Infinitys.webp" alt="" onerror="generate_Infinitys()" />
    </a>
    <h1>The Infinity's</h1>
    <button
      id="hamburger_menu_button"
      aria-label="hamburger_menu_button"
      onclick="hamburger_menu()">
      <div
      class="hamburger_menu_icon"
      id="open_hamburger_menu">
        <svg
          viewBox="0 0 100 100"
          fill="none"
          stroke-width="10">
          <line x1="10" y1="20" x2="90" y2="20" />
          <line x1="10" y1="50" x2="90" y2="50" />
          <line x1="10" y1="80" x2="90" y2="80" />
        </svg>
      </div>
      <div
      class="hamburger_menu_icon"
      id="close_hamburger_menu"
      style="opacity:0;"
      >
        <svg
          viewBox="-60 -60 120 120"
          fill="none"
          >
          <ellipse cx="-25" cy="0" rx="25" ry="20" stroke-width="2" />
          <ellipse cx="25" cy="0" rx="25" ry="20" stroke-width="2" />
          <circle cx="0" cy="0" r="50" stroke-width="4" />
        </svg>
      </div>
    </button>
    <!--hamburger menu-->
    <table id="hamburger_menus">
      <tr>
        <th scope="col">
          <!--icon-->
        </th>
          <!--name-->
        <th scope="col">
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            loading="lazy"
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th><a aria-label="Home" href="/">Home </a></th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="/blog/">Blog </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://scratch.mit.edu/users/The_Infinitys">Scratch </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://github.com/The-Infinitys">GitHub </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://x.com/Mugen_Infinitys/">X </a>
        </th>
      </tr>
    </table>
`;
  const header = document.createElement("header");
  header.style = `
  animation-name: show;
  animation-duration: 1s;
  animation-timing-function: linear;
  animation-iteration-count: initial;
  `;
  header.innerHTML = header_text;
  document.body.prepend(header);
};

const init_footer = function () {
  //headerの初期化
  const footer_text = `
    <div>
      <div>
        <p><a href="/contact/">Contact to The Infinity's</a></p>
        <p><a href="/blog/">Watch The Infinity's Blog</a></p>
        <p><a href="https://scratch.mit.edu/users/The_Infinitys/">Go to Scratch profile</a></p>
        <p><a href="https://github.com/The_Infinitys/">Go to GitHub profile</a></p>
      </div>
    </div>
    <h1>&copy; 2024 The Infinity's</h1>
  `;
  const footer = document.createElement("footer");
  footer.style = `
  animation-name: show;
  animation-duration: 1s;
  animation-timing-function: linear;
  animation-iteration-count: initial;
  `;
  footer.innerHTML = footer_text;
  document.body.append(footer);
};
const generate_Infinitys = function () {
  const The_Infinitys = (size, quality) => {
    const hsvToRgb16 = function (hue, saturation, value) {
      var result = false;
      if (
        (saturation || saturation === 0) &&
        saturation <= 100 &&
        (value || value === 0) &&
        value <= 100
      ) {
        var red = 0,
          green = 0,
          blue = 0,
          i = 0,
          f = 0,
          q = 0,
          p = 0,
          t = 0;
        hue = Number(hue % 360) / 60;
        saturation = Number(saturation) / 100;
        value = Number(value) / 100;
        if (saturation === 0) {
          red = value;
          green = value;
          blue = value;
        } else {
          i = Math.floor(hue);
          f = hue - i;
          p = value * (1 - saturation);
          q = value * (1 - saturation * f);
          t = value * (1 - saturation * (1 - f));
          switch (i) {
            case 0:
              red = value;
              green = t;
              blue = p;
              break;
            case 1:
              red = q;
              green = value;
              blue = p;
              break;
            case 2:
              red = p;
              green = value;
              blue = t;
              break;
            case 3:
              red = p;
              green = q;
              blue = value;
              break;
            case 4:
              red = t;
              green = p;
              blue = value;
              break;
            case 5:
              red = value;
              green = p;
              blue = q;
              break;
          }
        }
        result = {
          red: Math.round(red * 255).toString(),
          green: Math.round(green * 255).toString(),
          blue: Math.round(blue * 255).toString(),
        };
      }
      return "rgb(" + result.red + "," + result.green + "," + result.blue + ")";
    };
    const inf = (t) => {
      if (t < 0 || 720 < t) {
        return inf(t % 720);
      }
      const r = t * (Math.PI / 180);
      if (t < 360) {
        return {
          x: 100 * (Math.cos(r) - 1),
          y: Math.sin(r) * 80,
        };
      } else {
        return {
          x: -100 * (Math.cos(r) - 1),
          y: Math.sin(r) * 80,
        };
      }
    };
    const circle = (t) => {
      if (t < 0 || 360 < t) {
        return circle(t % 360);
      }
      const r = t * (Math.PI / 180);
      return {
        x: Math.cos(r),
        y: Math.sin(r),
      };
    };
    const canvas = document.createElement("canvas");
    canvas.width = size;
    canvas.height = size;
    const graphics = canvas.getContext("2d");
    graphics.clearRect(0, 0, canvas.width, canvas.height);
    let before_data = inf(0);
    graphics.lineWidth = canvas.width / 57;
    for (let i = 0; i <= 720; i += quality) {
      const data = inf(i);
      graphics.beginPath();
      graphics.moveTo(
        (before_data.x * canvas.width) / 500 + canvas.width / 2,
        (before_data.y * canvas.height) / 500 + canvas.height / 2
      );
      graphics.lineTo(
        (data.x * canvas.width) / 500 + canvas.width / 2,
        (data.y * canvas.height) / 500 + canvas.height / 2
      );
      graphics.closePath();
      graphics.strokeStyle = hsvToRgb16(((data.x + 200) / 400) * 360, 100, 100);
      graphics.stroke();
      before_data = data;
    }
    before_data = circle(0);
    graphics.lineWidth = canvas.width / 777;
    for (let count = 0; count < 777; count += quality * 10) {
      for (let t = 0; t <= 360; t += quality) {
        let data = circle(t);
        data.x *= 1 - count / 7777;
        data.y *= 1 - count / 7777;
        graphics.beginPath();
        graphics.moveTo(
          (before_data.x * canvas.width) / 2.22 + canvas.width / 2,
          (before_data.y * canvas.height) / 2.22 + canvas.height / 2
        );
        graphics.lineTo(
          (data.x * canvas.width) / 2.22 + canvas.width / 2,
          (data.y * canvas.height) / 2.22 + canvas.height / 2
        );
        graphics.closePath();
        graphics.strokeStyle = hsvToRgb16(
          (t + 360 + count / 7.7) % 360,
          100,
          100
        );
        graphics.stroke();
        before_data = data;
      }
    }
    return canvas.toDataURL("image/webp", 1);
  };
  const elems = document.getElementsByClassName("The-Infinitys");
  for (let i = 0; i < elems.length; ++i) {
    elems[i].src = The_Infinitys(400, 2);
  }
};
//ハンバーガーメニューの設定
let is_opened_hamburgerMenu = false;
function hamburger_menu() {
  is_opened_hamburgerMenu = !is_opened_hamburgerMenu;
  const menu = document.querySelector("#hamburger_menus");
  const open_button = document.querySelector("#open_hamburger_menu");
  const close_button = document.querySelector("#close_hamburger_menu");
  if (is_opened_hamburgerMenu) {
    //open the menu
    open_button.classList.remove("hamburger_menu_icon_show");
    open_button.classList.add("hamburger_menu_icon_hide");
    close_button.classList.remove("hamburger_menu_icon_hide");
    close_button.classList.add("hamburger_menu_icon_show");
    menu.classList.add("hamburger-open");
    menu.classList.remove("hamburger-close");
    open_button.style.opacity = "0";
    close_button.style.opacity = "1";
    menu.style.left = "calc(100vw - var(--hamburger-width))";
    menu.style.opacity = "1";
  } else {
    //close the menu
    open_button.classList.add("hamburger_menu_icon_show");
    open_button.classList.remove("hamburger_menu_icon_hide");
    close_button.classList.add("hamburger_menu_icon_hide");
    close_button.classList.remove("hamburger_menu_icon_show");
    menu.classList.add("hamburger-close");
    menu.classList.remove("hamburger-open");
    open_button.style.opacity = "1";
    close_button.style.opacity = "0";
    menu.style.left = "100vw";
    menu.style.opacity = "0";
  }
}
const generate_honeycomb = () => {
  //ダークモード・ライトモード対応
  const root3 = 1.7320508;
  const RainbowHoneycomb = document.createElement("canvas");
  RainbowHoneycomb.id = "RainbowHoneycomb";
  RainbowHoneycomb.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-100;
    animation-name: show;
    animation-duration: 1s;
    animation-timing-function: linear;
    animation-iteration-count: initial;
  `;
  document.body.append(RainbowHoneycomb);
  const draw = RainbowHoneycomb.getContext("2d");
  const rainbow_svg = document.createElement("div");
  rainbow_svg.id = "rainbow-back";
  document.body.append(rainbow_svg);
  const honeycomb = (x, y, r, color) => {
    draw.fillStyle = color;
    draw.beginPath();
    draw.moveTo(x, y - r);
    draw.lineTo(x + (root3 / 2) * r, y - r / 2);
    draw.lineTo(x + (root3 / 2) * r, y + r / 2);
    draw.lineTo(x, y + r);
    draw.lineTo(x - (root3 / 2) * r, y + r / 2);
    draw.lineTo(x - (root3 / 2) * r, y - r / 2);
    draw.fill();
  };
  const radius = 50;
  const radius_percent = 1.12;
  // const hsvToRgb16 = function (hue, saturation, value) {
  //   var result = false;
  //   if (
  //     (saturation || saturation === 0) &&
  //     saturation <= 100 &&
  //     (value || value === 0) &&
  //     value <= 100
  //   ) {
  //     var red = 0,
  //       green = 0,
  //       blue = 0,
  //       i = 0,
  //       f = 0,
  //       q = 0,
  //       p = 0,
  //       t = 0;
  //     hue = Number(hue % 360) / 60;
  //     saturation = Number(saturation) / 100;
  //     value = Number(value) / 100;
  //     if (saturation === 0) {
  //       red = value;
  //       green = value;
  //       blue = value;
  //     } else {
  //       i = Math.floor(hue);
  //       f = hue - i;
  //       p = value * (1 - saturation);
  //       q = value * (1 - saturation * f);
  //       t = value * (1 - saturation * (1 - f));
  //       switch (i) {
  //         case 0:
  //           red = value;
  //           green = t;
  //           blue = p;
  //           break;
  //         case 1:
  //           red = q;
  //           green = value;
  //           blue = p;
  //           break;
  //         case 2:
  //           red = p;
  //           green = value;
  //           blue = t;
  //           break;
  //         case 3:
  //           red = p;
  //           green = q;
  //           blue = value;
  //           break;
  //         case 4:
  //           red = t;
  //           green = p;
  //           blue = value;
  //           break;
  //         case 5:
  //           red = value;
  //           green = p;
  //           blue = q;
  //           break;
  //       }
  //     }
  //     result = {
  //       red: Math.round(red * 255).toString(),
  //       green: Math.round(green * 255).toString(),
  //       blue: Math.round(blue * 255).toString(),
  //     };
  //   }
  //   return "rgb(" + result.red + "," + result.green + "," + result.blue + ")";
  // };
  const drawhoneycomb = (color) => {
    draw.clearRect(0, 0, RainbowHoneycomb.width, RainbowHoneycomb.height);
    for (let i = 0; i < Math.round(RainbowHoneycomb.width / radius) + 2; ++i) {
      for (
        let j = 0;
        j < Math.round(RainbowHoneycomb.height / radius) + 2;
        ++j
      ) {
        honeycomb(
          radius * 2 * i + (j % 2) * radius,
          ((radius * 2 * root3) / 2) * j,
          radius * radius_percent,
          color
        );
      }
    }
  };

  const renewHoneycombCanvas = () => {
    RainbowHoneycomb.width = window.innerWidth * window.devicePixelRatio;
    RainbowHoneycomb.height = window.innerHeight * window.devicePixelRatio;
    if (window.matchMedia("(prefers-color-scheme: dark)").matches) {
      drawhoneycomb("#000");
    } else {
      drawhoneycomb("#fff");
    }
  };
  renewHoneycombCanvas();
  window.onresize = renewHoneycombCanvas;
  const mediaQueryList = window.matchMedia("(prefers-color-scheme: dark)");
  // 最初の判定
  if (mediaQueryList.matches) {
    console.log("dark-mode is enabled.");
  } else {
    console.log("light-mode is enabled");
  }
  // メディアクエリの変化を監視するリスナー関数を定義
  const listener_honeycomb = function (event) {
    if (event.matches) {
      console.log("swaped to dark-mode");
    } else {
      console.log("swaped to light-mode");
    }
    renewHoneycombCanvas();
  };
  mediaQueryList.addEventListener("change", listener_honeycomb);
};
const generate_style = () => {
  const dark_back = document.createElement("img");
  dark_back.src =
    "";
  dark_back.id = "dark-mobile";
  dark_back.alt = "";
  dark_back.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-1000;
  `;
  document.body.append(dark_back);
  const light_back = document.createElement("img");
  light_back.src =
    "";
  light_back.id = "light-mobile";
  light_back.alt = "";
  light_back.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-999;
  `;
  document.body.append(light_back);
  const center_inf = document.createElement("img");
  center_inf.src =
    "";
  center_inf.alt = "";
  center_inf.style = `
    position:fixed;
    width:50vw;
    height:50vw;
    transform: translate(-50%,-50%);
    top:50vh;
    left:50vw;
    z-index:-100;
    animation-name: show;
    animation-duration: 2s;
    animation-timing-function: linear;
    animation-iteration-count: initial;
  `;
  document.body.append(center_inf);
};

const is_phone = () => {
  const ua = navigator.userAgent;
  if (ua.indexOf("iPhone") >= 0) {
    return true;
  }
  if (ua.indexOf("iPad") >= 0) {
    return true;
  }
  if (ua.indexOf("Android") >= 0) {
    return true;
  }
  return false;
};

const The_Infinitys_main = () => {
  init_header();
  init_footer();
  if (Math.random() < 0) {
    generate_style();
  } else {
    generate_honeycomb();
  }
};
The_Infinitys_main();
          

変更後

const init_header = function () {
  //headerの初期化
  const header_text = `
    <a href="/" aria-label="Home">
      <img id="headerLogo" class="The-Infinitys" src="/image/The-Infinitys.webp" alt="" onerror="generate_Infinitys()" />
    </a>
    <h1>The Infinity's</h1>
    <button
      id="hamburger_menu_button"
      aria-label="hamburger_menu_button"
      onclick="hamburger_menu()">
      <div
      class="hamburger_menu_icon"
      id="open_hamburger_menu">
        <svg
          viewBox="0 0 100 100"
          fill="none"
          stroke-width="10">
          <line x1="10" y1="20" x2="90" y2="20" />
          <line x1="10" y1="50" x2="90" y2="50" />
          <line x1="10" y1="80" x2="90" y2="80" />
        </svg>
      </div>
      <div
      class="hamburger_menu_icon"
      id="close_hamburger_menu"
      style="opacity:0;"
      >
        <svg
          viewBox="-60 -60 120 120"
          fill="none"
          >
          <ellipse cx="-25" cy="0" rx="25" ry="20" stroke-width="2" />
          <ellipse cx="25" cy="0" rx="25" ry="20" stroke-width="2" />
          <circle cx="0" cy="0" r="50" stroke-width="4" />
        </svg>
      </div>
    </button>
    <!--hamburger menu-->
    <table id="hamburger_menus">
      <tr>
        <th scope="col">
          <!--icon-->
        </th>
          <!--name-->
        <th scope="col">
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            loading="lazy"
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th><a aria-label="Home" href="/">Home </a></th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="/blog/">Blog </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://scratch.mit.edu/users/The_Infinitys">Scratch </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://github.com/The-Infinitys">GitHub </a>
        </th>
      </tr>
      <tr>
        <th>
          <img
            alt=""
            class="hamburger_menus-contents-icons"
            src="" />
        </th>
        <th>
          <a href="https://x.com/Mugen_Infinitys/">X </a>
        </th>
      </tr>
    </table>
`;
  const header = document.createElement("header");
  header.style = `
  animation-name: show;
  animation-duration: 1s;
  animation-timing-function: linear;
  animation-iteration-count: initial;
  `;
  header.innerHTML = header_text;
  document.body.prepend(header);
};

const init_footer = function () {
  //headerの初期化
  const footer_text = `
    <div>
      <div>
        <p><a href="/contact/">Contact to The Infinity's</a></p>
        <p><a href="/blog/">Watch The Infinity's Blog</a></p>
        <p><a href="https://scratch.mit.edu/users/The_Infinitys/">Go to Scratch profile</a></p>
        <p><a href="https://github.com/The_Infinitys/">Go to GitHub profile</a></p>
      </div>
    </div>
    <h1>&copy; 2024 The Infinity's</h1>
  `;
  const footer = document.createElement("footer");
  footer.style = `
  animation-name: show;
  animation-duration: 1s;
  animation-timing-function: linear;
  animation-iteration-count: initial;
  `;
  footer.innerHTML = footer_text;
  document.body.append(footer);
};
const generate_Infinitys = function () {
  const The_Infinitys = (size, quality) => {
    const hsvToRgb16 = function (hue, saturation, value) {
      var result = false;
      if (
        (saturation || saturation === 0) &&
        saturation <= 100 &&
        (value || value === 0) &&
        value <= 100
      ) {
        var red = 0,
          green = 0,
          blue = 0,
          i = 0,
          f = 0,
          q = 0,
          p = 0,
          t = 0;
        hue = Number(hue % 360) / 60;
        saturation = Number(saturation) / 100;
        value = Number(value) / 100;
        if (saturation === 0) {
          red = value;
          green = value;
          blue = value;
        } else {
          i = Math.floor(hue);
          f = hue - i;
          p = value * (1 - saturation);
          q = value * (1 - saturation * f);
          t = value * (1 - saturation * (1 - f));
          switch (i) {
            case 0:
              red = value;
              green = t;
              blue = p;
              break;
            case 1:
              red = q;
              green = value;
              blue = p;
              break;
            case 2:
              red = p;
              green = value;
              blue = t;
              break;
            case 3:
              red = p;
              green = q;
              blue = value;
              break;
            case 4:
              red = t;
              green = p;
              blue = value;
              break;
            case 5:
              red = value;
              green = p;
              blue = q;
              break;
          }
        }
        result = {
          red: Math.round(red * 255).toString(),
          green: Math.round(green * 255).toString(),
          blue: Math.round(blue * 255).toString(),
        };
      }
      return "rgb(" + result.red + "," + result.green + "," + result.blue + ")";
    };
    const inf = (t) => {
      if (t < 0 || 720 < t) {
        return inf(t % 720);
      }
      const r = t * (Math.PI / 180);
      if (t < 360) {
        return {
          x: 100 * (Math.cos(r) - 1),
          y: Math.sin(r) * 80,
        };
      } else {
        return {
          x: -100 * (Math.cos(r) - 1),
          y: Math.sin(r) * 80,
        };
      }
    };
    const circle = (t) => {
      if (t < 0 || 360 < t) {
        return circle(t % 360);
      }
      const r = t * (Math.PI / 180);
      return {
        x: Math.cos(r),
        y: Math.sin(r),
      };
    };
    const canvas = document.createElement("canvas");
    canvas.width = size;
    canvas.height = size;
    const graphics = canvas.getContext("2d");
    graphics.clearRect(0, 0, canvas.width, canvas.height);
    let before_data = inf(0);
    graphics.lineWidth = canvas.width / 57;
    for (let i = 0; i <= 720; i += quality) {
      const data = inf(i);
      graphics.beginPath();
      graphics.moveTo(
        (before_data.x * canvas.width) / 500 + canvas.width / 2,
        (before_data.y * canvas.height) / 500 + canvas.height / 2
      );
      graphics.lineTo(
        (data.x * canvas.width) / 500 + canvas.width / 2,
        (data.y * canvas.height) / 500 + canvas.height / 2
      );
      graphics.closePath();
      graphics.strokeStyle = hsvToRgb16(((data.x + 200) / 400) * 360, 100, 100);
      graphics.stroke();
      before_data = data;
    }
    before_data = circle(0);
    graphics.lineWidth = canvas.width / 777;
    for (let count = 0; count < 777; count += quality * 10) {
      for (let t = 0; t <= 360; t += quality) {
        let data = circle(t);
        data.x *= 1 - count / 7777;
        data.y *= 1 - count / 7777;
        graphics.beginPath();
        graphics.moveTo(
          (before_data.x * canvas.width) / 2.22 + canvas.width / 2,
          (before_data.y * canvas.height) / 2.22 + canvas.height / 2
        );
        graphics.lineTo(
          (data.x * canvas.width) / 2.22 + canvas.width / 2,
          (data.y * canvas.height) / 2.22 + canvas.height / 2
        );
        graphics.closePath();
        graphics.strokeStyle = hsvToRgb16(
          (t + 360 + count / 7.7) % 360,
          100,
          100
        );
        graphics.stroke();
        before_data = data;
      }
    }
    return canvas.toDataURL("image/webp", 1);
  };
  const elems = document.getElementsByClassName("The-Infinitys");
  for (let i = 0; i < elems.length; ++i) {
    elems[i].src = The_Infinitys(400, 2);
  }
};
//ハンバーガーメニューの設定
let is_opened_hamburgerMenu = false;
function hamburger_menu() {
  is_opened_hamburgerMenu = !is_opened_hamburgerMenu;
  const menu = document.querySelector("#hamburger_menus");
  const open_button = document.querySelector("#open_hamburger_menu");
  const close_button = document.querySelector("#close_hamburger_menu");
  if (is_opened_hamburgerMenu) {
    //open the menu
    open_button.classList.remove("hamburger_menu_icon_show");
    open_button.classList.add("hamburger_menu_icon_hide");
    close_button.classList.remove("hamburger_menu_icon_hide");
    close_button.classList.add("hamburger_menu_icon_show");
    menu.classList.add("hamburger-open");
    menu.classList.remove("hamburger-close");
    open_button.style.opacity = "0";
    close_button.style.opacity = "1";
    menu.style.left = "calc(100vw - var(--hamburger-width))";
    menu.style.opacity = "1";
  } else {
    //close the menu
    open_button.classList.add("hamburger_menu_icon_show");
    open_button.classList.remove("hamburger_menu_icon_hide");
    close_button.classList.add("hamburger_menu_icon_hide");
    close_button.classList.remove("hamburger_menu_icon_show");
    menu.classList.add("hamburger-close");
    menu.classList.remove("hamburger-open");
    open_button.style.opacity = "1";
    close_button.style.opacity = "0";
    menu.style.left = "100vw";
    menu.style.opacity = "0";
  }
}
const generate_honeycomb = (mode = "honeycomb") => {
  //ダークモード・ライトモード対応
  const root3 = 1.7320508;
  const RainbowHoneycomb = document.createElement("canvas");
  RainbowHoneycomb.id = "RainbowHoneycomb";
  RainbowHoneycomb.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-100;
    animation-name: show;
    animation-duration: 1s;
    animation-timing-function: linear;
    animation-iteration-count: initial;
  `;
  document.body.append(RainbowHoneycomb);
  const draw = RainbowHoneycomb.getContext("2d");
  const rainbow_svg = document.createElement("div");
  rainbow_svg.id = "rainbow-back";
  document.body.append(rainbow_svg);
  const honeycomb = (x, y, r, color, mode) => {
    if (mode == "honeycomb") {
      draw.fillStyle = color;
      draw.beginPath();
      draw.moveTo(x, y - r);
      draw.lineTo(x + (root3 / 2) * r, y - r / 2);
      draw.lineTo(x + (root3 / 2) * r, y + r / 2);
      draw.lineTo(x, y + r);
      draw.lineTo(x - (root3 / 2) * r, y + r / 2);
      draw.lineTo(x - (root3 / 2) * r, y - r / 2);
      draw.fill();
    } else {
      draw.strokeStyle = "#ff0";
      draw.lineWidth = 1;
      draw.globalCompositeOperation = "destination-out";
      draw.beginPath();
      draw.arc(x, y, r, 0, 2 * Math.PI, true);
      draw.closePath();
      draw.stroke();
      draw.globalCompositeOperation = "source-over";
    }
  };
  const radius = 50;
  const radius_percent = 1.12;
  // const hsvToRgb16 = function (hue, saturation, value) {
  //   var result = false;
  //   if (
  //     (saturation || saturation === 0) &&
  //     saturation <= 100 &&
  //     (value || value === 0) &&
  //     value <= 100
  //   ) {
  //     var red = 0,
  //       green = 0,
  //       blue = 0,
  //       i = 0,
  //       f = 0,
  //       q = 0,
  //       p = 0,
  //       t = 0;
  //     hue = Number(hue % 360) / 60;
  //     saturation = Number(saturation) / 100;
  //     value = Number(value) / 100;
  //     if (saturation === 0) {
  //       red = value;
  //       green = value;
  //       blue = value;
  //     } else {
  //       i = Math.floor(hue);
  //       f = hue - i;
  //       p = value * (1 - saturation);
  //       q = value * (1 - saturation * f);
  //       t = value * (1 - saturation * (1 - f));
  //       switch (i) {
  //         case 0:
  //           red = value;
  //           green = t;
  //           blue = p;
  //           break;
  //         case 1:
  //           red = q;
  //           green = value;
  //           blue = p;
  //           break;
  //         case 2:
  //           red = p;
  //           green = value;
  //           blue = t;
  //           break;
  //         case 3:
  //           red = p;
  //           green = q;
  //           blue = value;
  //           break;
  //         case 4:
  //           red = t;
  //           green = p;
  //           blue = value;
  //           break;
  //         case 5:
  //           red = value;
  //           green = p;
  //           blue = q;
  //           break;
  //       }
  //     }
  //     result = {
  //       red: Math.round(red * 255).toString(),
  //       green: Math.round(green * 255).toString(),
  //       blue: Math.round(blue * 255).toString(),
  //     };
  //   }
  //   return "rgb(" + result.red + "," + result.green + "," + result.blue + ")";
  // };
  const drawhoneycomb = (color) => {
    draw.clearRect(0, 0, RainbowHoneycomb.width, RainbowHoneycomb.height);
    if ((mode = "jp-spirit")) {
      draw.fillStyle = color;
      draw.fillRect(0, 0, RainbowHoneycomb.width, RainbowHoneycomb.height);
    }
    for (let i = 0; i < Math.round(RainbowHoneycomb.width / radius) + 2; ++i) {
      for (
        let j = 0;
        j < Math.round(RainbowHoneycomb.height / radius) + 2;
        ++j
      ) {
        honeycomb(
          radius * 2 * i + (j % 2) * radius,
          ((radius * 2 * root3) / 2) * j,
          radius * radius_percent,
          color,
          mode
        );
      }
    }
  };

  const renewHoneycombCanvas = () => {
    RainbowHoneycomb.width = window.innerWidth * window.devicePixelRatio;
    RainbowHoneycomb.height = window.innerHeight * window.devicePixelRatio;
    if (window.matchMedia("(prefers-color-scheme: dark)").matches) {
      drawhoneycomb("#000");
    } else {
      drawhoneycomb("#fff");
    }
  };
  renewHoneycombCanvas();
  window.onresize = renewHoneycombCanvas;
  const mediaQueryList = window.matchMedia("(prefers-color-scheme: dark)");
  // 最初の判定
  if (mediaQueryList.matches) {
    console.log("dark-mode is enabled.");
  } else {
    console.log("light-mode is enabled");
  }
  // メディアクエリの変化を監視するリスナー関数を定義
  const listener_honeycomb = function (event) {
    if (event.matches) {
      console.log("swaped to dark-mode");
    } else {
      console.log("swaped to light-mode");
    }
    renewHoneycombCanvas();
  };
  mediaQueryList.addEventListener("change", listener_honeycomb);
};
const generate_style = () => {
  const dark_back = document.createElement("img");
  dark_back.src =
    "";
  dark_back.id = "dark-mobile";
  dark_back.alt = "";
  dark_back.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-1000;
  `;
  document.body.append(dark_back);
  const light_back = document.createElement("img");
  light_back.src =
    "";
  light_back.id = "light-mobile";
  light_back.alt = "";
  light_back.style = `
    position:fixed;
    width:100vw;
    height:100vh;
    top:0;
    left:0;
    z-index:-999;
  `;
  document.body.append(light_back);
  const center_inf = document.createElement("img");
  center_inf.src =
    "";
  center_inf.alt = "";
  center_inf.style = `
    position:fixed;
    width:50vw;
    height:50vw;
    transform: translate(-50%,-50%);
    top:50vh;
    left:50vw;
    z-index:-100;
    animation-name: show;
    animation-duration: 2s;
    animation-timing-function: linear;
    animation-iteration-count: initial;
  `;
  document.body.append(center_inf);
};

const is_phone = () => {
  const ua = navigator.userAgent;
  if (ua.indexOf("iPhone") >= 0) {
    return true;
  }
  if (ua.indexOf("iPad") >= 0) {
    return true;
  }
  if (ua.indexOf("Android") >= 0) {
    return true;
  }
  return false;
};

const The_Infinitys_main = () => {
  init_header();
  init_footer();
  if (Math.random() < 0.1) {
    generate_style();
  } else if (Math.random() < 0.5) {
    generate_honeycomb((mode = "honeycomb"));
  } else {
    generate_honeycomb((mode = "jp-spirit"));
  }
};
The_Infinitys_main();
          

どこが変わったのか

私はJavaScriptでページを作るときに関数をfunctionではなく、()=>{}で定義するのですが…

const honeycomb = (x, y, r, color, mode) => {
  if (mode == "honeycomb") {
    draw.fillStyle = color;
    draw.beginPath();
    draw.moveTo(x, y - r);
    draw.lineTo(x + (root3 / 2) * r, y - r / 2);
    draw.lineTo(x + (root3 / 2) * r, y + r / 2);
    draw.lineTo(x, y + r);
    draw.lineTo(x - (root3 / 2) * r, y + r / 2);
    draw.lineTo(x - (root3 / 2) * r, y - r / 2);
    draw.fill();
  } else {
    draw.strokeStyle = "#ffff";
    draw.lineWidth = 1;
    draw.globalCompositeOperation = "destination-out";
    draw.beginPath();
    draw.arc(x, y, r, 0, 2 * Math.PI, true);
    draw.closePath();
    draw.stroke();
    draw.globalCompositeOperation = "source-over";
  }
};
          

この関数をみてください。
この関数が、ページの六角形の部分を書いていた関数なのですが、そこの部分に手を加えて、

draw.strokeStyle = "#ffff";
draw.lineWidth = 1;
draw.globalCompositeOperation = "destination-out";
draw.beginPath();
draw.arc(x, y, r, 0, 2 * Math.PI, true);
draw.closePath();
draw.stroke();
draw.globalCompositeOperation = "source-over";
          

円を繰り抜く事ができるようにしました。
はい。

いつの間にサイレントアプデ

実は最近ページをサイレントアップデートしていて、その影響で、画像を一切読み込まなくともトップページが正常に表示されるようになりました。^o^
⭐️キツかった⭐️

Copy To ClipBoard
Share On X