Pixiv Image Size Fitting

pixiv の原寸画像が表示領域に収まるように画像サイズを変更

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name        Pixiv Image Size Fitting
// @namespace   http://userscripts.org/users/121129
// @description pixiv の原寸画像が表示領域に収まるように画像サイズを変更
// @include     *://www.pixiv.net/*
// @version     12
// @grant       none
// @license     MIT
// @noframes
// ==/UserScript==

;(function() {
  'use strict'
  function hasModifiersKey(event) {
    return event.altKey || event.ctrlKey || event.metaKey || event.shiftKey
  }
  function addStyle() {
    const style = document.createElement('style')
    style.id = 'PixivImageSizeFittingStyle'
    style.textContent = `
      body > [role="presentation"] > div > div {
        overflow: hidden;
      }
      body > [role="presentation"] img {
        max-height: 100vh;
        max-width: 100vw;
      }
    `
    document.head.appendChild(style)
  }
  function keydown(e) {
    if (hasModifiersKey(e)) return
    if (!['x', 'i'].includes(e.key)) return
    const style = document.getElementById('PixivImageSizeFittingStyle')
    if (style) {
      style.remove()
    } else {
      addStyle()
    }
  }
  function main() {
    addStyle()
    window.addEventListener('keydown', keydown)
  }
  main()
})()