FuckImage

摸鱼大法好,隐藏或缩小页面中的图片,别让老板在十万八千里外就能看到你在摸鱼!

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         FuckImage
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  摸鱼大法好,隐藏或缩小页面中的图片,别让老板在十万八千里外就能看到你在摸鱼!
// @author       [email protected]
// @match        *://*/*
// @grant        none
// @exclude      https://lanhuapp.com/*
// @exclude      *://localhost:*/*
// @exclude      *://*.*.*.*/*
// @exclude      *://*.*.*.*:*/*
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    let imageArr = document.getElementsByTagName('img')

    let currentWork = null // 'hide' 'show' 'mini'

    let timer = null

    let miniSizeDefault = 50

    let color = "#f4b579"

    let picture = ""
    let activeShow = ""
    let grayShow = ""
    let activeHide = ""
    let grayHide = ""
    let zoom = ""

    function addGlobalStyle(css) {
        var head, style;
        head = document.getElementsByTagName('head')[0];
        if (!head) { return; }
        style = document.createElement('style');
        style.type = 'text/css';
        style.innerHTML = css;
        head.appendChild(style);
    }

    function hideShowImg(action){
        for(let i = 0; i < imageArr.length; i++) {
            let imageItem = imageArr[i]
            let sizeType = imageItem.width > imageItem.height ? 'width' : 'height'
            let miniSizeInputValue = +document.getElementById("zk-mini-size-input").value
            let miniSize = miniSizeInputValue && miniSizeInputValue >= 0 ? miniSizeInputValue : miniSizeDefault
            if(action) { console.log(action)}
            switch(action) {
                case 'show':
                    //console.log('show')
                    imageItem.style.display = ''
                    imageItem.style.width = ''
                    imageItem.style.height = ''
                    break
                case 'hide':
                    //console.log('hide')
                    imageItem.style.display = 'none'
                    imageItem.style.width = ''
                    imageItem.style.height = ''
                    break
                case 'mini':
                    //console.log('mini')
                    imageItem.style.display = ''
                    imageItem[sizeType] > miniSize && (imageItem.style[sizeType] = `${miniSize}px`)
                    break
            }
        }
    }

    function hideImg() { hideShowImg('hide')}

    function showImg() { hideShowImg('show')}

    function miniImg() { hideShowImg('mini')}

    function createBtn() {
        let container = document.createElement('DIV')
        container.id = "zk-image-container"
        container.innerHTML = `
            <i class="logo-img zk-item"></i>
            <span id="zk-hide-image-btn" class="zk-image-btn zk-item" title="隐藏图片"></span>
            <span id="zk-show-image-btn" class="zk-image-btn zk-item" title="显示图片"></span>
            <input class="size-input zk-item" placeholder="50" id="zk-mini-size-input"/>
            <span id="zk-mini-image-btn" class="zk-image-btn zk-item" title="缩小图片"></span>`
        document.body.appendChild(container)
        //document.getElementById("zk-mini-size-input").value = miniSizeDefault
        //container.style.position = 'fixed'
        //container.style.right="100px"
        //container.style.top="100px"
        //container.style.zIndex=1000000000



        addGlobalStyle(`#zk-image-container { position: fixed; right: -170px; top: 100px; z-index: 1000000; background-image: linear-gradient(120deg, #84fab0 0%, #8fd3f4 100%); height: 44px; line-height: 44px; border-radius: 22px 0 0 22px; padding: 0 22px; transition: all 300ms;}` )
        addGlobalStyle(`#zk-image-container:hover { right: 0; transition: all 300ms}`)
        addGlobalStyle(`#zk-image-container .logo-img{ background-image: url(${picture}); display: inline-block; width: 32px; height: 32px; background-size: 100% 100%; position: relative; left: -16px;}`)
        addGlobalStyle(`#zk-image-container .zk-image-btn{cursor: pointer; display: inline-block; width: 32px; height: 32px; background-size: 100% 100%; background-repeat: no-repeat;}`)
        addGlobalStyle(`#zk-image-container .size-input.zk-item { display: inline-block; height: 20px; width: 20px; border: none; outline: none; font-size: 12px; line-height: 20px; margin-top: 11px; margin-left: 4px; padding: 0; vertical-align: top; background: transparent; border-bottom: 1px solid ${color}; color:${color};}`)

        addGlobalStyle(`#zk-image-container #zk-hide-image-btn { background-image: url(${activeHide})}`)
        addGlobalStyle(`#zk-image-container #zk-show-image-btn { background-image: url(${activeShow})}`)
        addGlobalStyle(`#zk-image-container #zk-mini-image-btn { background-image: url(${zoom}); background-size: 24px 24px; background-position: center center; }`)
        addGlobalStyle(`#zk-image-container .zk-item { margin-top: 6px}`)
    }

    function bind() {
        document.getElementById("zk-hide-image-btn").addEventListener('click', ev => {
            hideImg()
            currentWork = 'hide'
        })
        document.getElementById("zk-show-image-btn").addEventListener('click', ev => {
            showImg()
            currentWork = 'show'
        })
        document.getElementById("zk-mini-image-btn").addEventListener('click', ev => {
            miniImg()
            currentWork = 'mini'
        })
    }

    function setTimeWork() {
        timer && clearInterval(timer)
        timer = setInterval(() => {
            currentWork && hideShowImg(currentWork)
            if(!document.getElementById("zk-image-container")){
                createBtn()
                bind()
            }
        }, 50)
    }


    createBtn()
    bind()
    setTimeWork()

})();