图片移动缩放旋转

shift+alt+z/x放大/缩小,+q/e左/右旋转,wasd移动,+r恢复,+c重新读取图片。

目前為 2025-11-20 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         图片移动缩放旋转
// @version      1.0.2
// @description  shift+alt+z/x放大/缩小,+q/e左/右旋转,wasd移动,+r恢复,+c重新读取图片。
// @author       dianclar
// @match        *://*/*
// @license      GPL
// @grant        none
// @namespace https://greasyfork.org/users/1538433
// ==/UserScript==

;(function () {
  'use strict'

  //可以修改缩放程度
  const stylevalue = 10
  //可以修改移动程度
  const locationvalue = 10
  //可以修改旋转程度
  const rotationvalue = 90
  let stylei = 0
  let rotation = 0
  let xi = 0
  let yi = 0

  let imglist = []
  let imgs = document.querySelectorAll('img')
  document.addEventListener('keydown', function (event) {
    if (event.shiftKey && event.altKey && event.code === 'KeyC') {
      imgs = document.querySelectorAll('img')
      imgpaly()
    }
  })
  function imgpaly() {
    if (!imgs.length == 0) {
      imgs.forEach((img) => {
        img.style.objectFit = 'contain'
        const rect = img.getBoundingClientRect()
        imglist.push({
          width: rect.width,
          height: rect.height,
          x: rect.x,
          y: rect.y
        })
      })
      document.addEventListener('keydown', function (event) {
        if (event.shiftKey && event.altKey && event.code === 'KeyZ') {
          stylei--
          imgs.forEach((img, i) => {
            img.style.height = imglist[i].height * (stylevalue * stylei + 100) * 0.01 + 'px'
            img.style.width = imglist[i].width * (stylevalue * stylei + 100) * 0.01 + 'px'
          })
        }
        if (event.shiftKey && event.altKey && event.code === 'KeyX') {
          stylei++
          imgs.forEach((img, i) => {
            img.style.height = imglist[i].height * (stylevalue * stylei + 100) * 0.01 + 'px'
            img.style.width = imglist[i].width * (stylevalue * stylei + 100) * 0.01 + 'px'
          })
        }

        if (event.shiftKey && event.altKey && event.code === 'KeyE') {
          rotation += rotationvalue
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }
        if (event.shiftKey && event.altKey && event.code === 'KeyQ') {
          rotation -= rotationvalue
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }

        if (event.shiftKey && event.altKey && event.code === 'KeyW') {
          yi--
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }
        if (event.shiftKey && event.altKey && event.code === 'KeyS') {
          yi++
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }
        if (event.shiftKey && event.altKey && event.code === 'KeyA') {
          xi--
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }
        if (event.shiftKey && event.altKey && event.code === 'KeyD') {
          xi++
          imgs.forEach((img) => {
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }

        if (event.shiftKey && event.altKey && event.code === 'KeyR') {
          stylei = 0
          rotation = 0
          xi = 0
          yi = 0
          imgs.forEach((img,i) => {
            img.style.height = imglist[i].height * (stylevalue * stylei + 100) * 0.01 + 'px'
            img.style.width = imglist[i].width * (stylevalue * stylei + 100) * 0.01 + 'px'
            img.style.transform = `translateX(${xi * locationvalue}px) translateY(${yi * locationvalue}px) rotate(${rotation}deg)`
          })
        }
      })
    }
  }
  imgpaly()
})()