// ==UserScript==
// @name xgyw 秀人网查看大图写真
// @namespace http://tampermonkey.net/
// @version 1.3.4
// @description 针对xgyw网站上写真的脚本,同时提供打包下载功能
// @author xzwzz
// @match https://www.xgmn5.top/*/*
// @match https://www.xinggan5.top/*/*
// @match https://www.xiuren009.top/*/*
// @match https://www.ik009.top/*/*
// @grant GM_openInTab
// @grant GM_registerMenuCommand
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_deleteValue
// @grant GM_xmlhttpRequest
// @grant GM_download
// @require https://update.greasyfork.org/scripts/449471/1413235/Viewer.js
// @require http://libs.baidu.com/jquery/2.0.0/jquery.js
// @require https://update.greasyfork.org/scripts/498742/1399645/jszip1.js
// @require https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2.0.0/FileSaver.min.js
// ==/UserScript==
var downloadCnt = 0; //下载中的图片
var photoSize = 200 //图片宽度
let convertPage; //需要显示的page
let imageViewer;//图片的集合
let toolBox;//工具集
let thumbTitle;//相册标题
let webHost;
let switchBtn;
let streams = {
"ik009":{
loadThumbnail:()=>{
var host = self.location.origin;
let addImages;
let items;
addImages = (info,host,document)=>{
var url = info.getAttribute("href")
let pageUrl = url
$.get(pageUrl,function (data) {
var nImages = $(".info-imtg-box p img", data);
for (var index = 0; index < nImages.length; index++) {
var origin = nImages[index];
origin.style.cssText = "width:200px"
info.append(origin)
}
})
}
items = $(".node .sousuo .title a")
for (var index = 0;index<items.length;index++){
let item = items[index];
addImages(item,host,this)
}
},
loadTitle:()=>{
return $(".f-22")[0].innerText;
},
loadPages:()=>{
var newStr = self.location.origin;
let pageUrls = []
let pagination = $(".pagebar")[0];
let pages = $("a", pagination)
for (var i = 0; i < pages.length; i++) {
var page = pages[i];
if (page.innerText == "上一页" || page.innerText == "下一页") {
} else {
let next = newStr + $(page).attr("href")
pageUrls.push(next)
}
}
return pageUrls;
},
imgPattern:".info-imtg-box p img"
},
"xiuren009":{
loadThumbnail:()=>{
var host = self.location.origin;
let addImages;
let items;
console.log(this.imgPattern)
addImages = (info,host,document)=>{
var url = info.getAttribute("href")
let pageUrl = url
$.get(pageUrl,function (data) {
var nImages = $(".main_inner .content p img", data);
for (var index = 0; index < nImages.length; index++) {
var origin = nImages[index];
origin.style.cssText = "width:200px"
info.append(origin)
}
})
}
items = $(".node .sousuo .title a")
for (var index = 0;index<items.length;index++){
let item = items[index];
addImages(item,host,this)
}},
loadTitle:()=>{
return $("title")[0].innerText;
},
loadPages:()=>{
var newStr = self.location.origin;
let pageUrls = []
let pagination = $(".page")[0];
let pages = $("a", pagination)
for (var i = 0; i < pages.length; i++) {
var page = pages[i];
if (page.innerText == "上一页" || page.innerText == "下页") {
} else {
let subfix=$(page).attr("href")
if(subfix){
let next = newStr + subfix
pageUrls.push(next)
}
}
}
return pageUrls
},
imgPattern:".main_inner .content p img"
},
"xgmn5":{
loadThumbnail:()=>{
var host = self.location.origin;
let addImages;
let items;
addImages = (info,host,document)=>{
var url = info.getAttribute("href")
let pageUrl = url
$.get(pageUrl,function (data) {
var nImages = $(".article-content p img", data);
for (var index = 0; index < nImages.length; index++) {
var origin = nImages[index];
origin.style.cssText = "width:200px"
info.append(origin)
}
})
}
items = $(".node .description p a")
for (var index = 0;index<items.length;index++){
let item = items[index];
addImages(item,host,this)
}},
loadTitle:()=>{
var meta = $(".article-meta span a")[0].innerText
var title = $(".article-title")[0].innerText
return meta+"-"+title
},
loadPages:()=>{
var newStr = self.location.origin;
let pageUrls = []
let pagination = $(".pagination")[0];
let pages = $("ul a", pagination)
for (var i = 0; i < pages.length; i++) {
var page = pages[i];
if (page.innerText == "上一页" || page.innerText == "下一页") {
} else {
let next = newStr + $(page).attr("href")
pageUrls.push(next)
}
}
return pageUrls
},
imgPattern:".article-content p img"
},
"xinggan5":{
loadThumbnail:()=>{
var host = self.location.origin;
let addImages;
let items;
addImages = (info,host,document)=>{
var url = info.getAttribute("href")
let pageUrl = url
$.get(pageUrl,function (data) {
var nImages = $(".article-content p img", data);
for (var index = 0; index < nImages.length; index++) {
var origin = nImages[index];
origin.style.cssText = "width:200px"
info.append(origin)
}
})
}
items = $(".node .description p a")
for (var index = 0;index<items.length;index++){
let item = items[index];
addImages(item,host,this)
}},
loadTitle:()=>{
var meta = $(".article-meta span a")[0].innerText
var title = $(".article-title")[0].innerText
return meta+"-"+title
},
loadPages:()=>{
var newStr = self.location.origin;
let pageUrls = []
let pagination = $(".pagination")[0];
let pages = $("ul a", pagination)
for (var i = 0; i < pages.length; i++) {
var page = pages[i];
if (page.innerText == "上一页" || page.innerText == "下一页") {
} else {
let next = newStr + $(page).attr("href")
pageUrls.push(next)
}
}
return pageUrls
},
imgPattern:".article-content p img"
}
}
function searchWebObject(origin){
let key = origin.split(".")[1];
return streams[key]
}
function loadDetailPage(){
console.log("start loading")
initStyle();
'use strict';
console.log("start parsing urls")
let obj = searchWebObject(webHost)
let pageUrls = obj.loadPages()
console.log(pageUrls);
let allImagesP = []
var nImages = $(obj.imgPattern);
for (var index = 1; index < nImages.length; index++) {
var item = $(nImages[index]);
allImagesP.push({index: 0 + "." + index, data: item[0]})
}
console.log(allImagesP);
console.log("start parsing pages")
thumbTitle = obj.loadTitle()
initShowPages()
createButton("下载原图",()=>{
handleBatchDownload(allImagesP,thumbTitle)
})
createButton("切换尺寸",()=>{
if(photoSize==200){
photoSize = 400
}else if(photoSize == 400){
photoSize = 600
}else if(photoSize == 600){
photoSize = 1200
}else if(photoSize == 1200){
photoSize = 200
}
for (var i = 0; i < allImagesP.length; i++) {
var item = $(allImagesP[i].data);
item.attr("width", photoSize);
item.attr("style", "float:left;");
}
})
convertPage.append(imageViewer);
console.log("start load images")
new Promise((ret,reject)=>{
for (var j = 0; j < pageUrls.length; j++) {
downloadCnt++;
var p = pageUrls[j];
requestChildUrl(obj,j, p, allImagesP)
}
ret(true)
}).then((res)=>{
if(allImagesP.length == 0){
switchBtn.click();
}
var inter = setInterval(() => {
if (downloadCnt == 0) {
allImagesP.sort(function (a, b) {
return parseFloat(a.index) - parseFloat(b.index)
})
for (var i = 0; i < allImagesP.length; i++) {
var item = $(allImagesP[i].data);
var imgli = $('<li></li>');
item.attr("width", photoSize);
item.attr("style", "float:left;");
imgli = imgli.append(item);
imageViewer.append(imgli)
}
clearInterval(inter)
}
}, 100)
})
}
function requestChildUrl(webObj,i, page, list) {
$.get(page, function (data) {
var nImages = $(webObj.imgPattern,data)
for (var index = 0; index < nImages.length; index++) {
var item = $(nImages[index]);
list.push({index: i + "." + index, data: item[0]})
}
downloadCnt--;
})
}
function getBase64(image) {
return new Promise((resolve) => {
try {
GM_xmlhttpRequest({
method: "get",
url: image.src,
responseType: "blob",
onload: function (r) {
var blob = r.response;
let oFileReader = new FileReader();
oFileReader.onloadend = function (e) {
let base64 = e.target.result;
if (base64.startsWith("data:image")) {
// zipFilteredImgUrls[urlIndex] = base64;
//zipImgWaitDownload.push(base64);
resolve(base64)
}
};
oFileReader.readAsDataURL(blob);
}
});
} catch (e) {
console.log(e)
}
});
}
// 批量下载
let handleBatchDownload = async (selectImgList,saveName) => {
const data = selectImgList;
try {
var zipFolder = new JSZip();
var zipSubFoler = zipFolder.folder(saveName);
} catch {
}
const cache = {}
const promises = []
await data.forEach(item => {
const promise = getBase64(item.data).then(img => { // 下载文件, 并存成ArrayBuffer对象
try {
let fileExt = img.substring(img.indexOf("image/") + 6, img.indexOf(";"))
fileExt = fileExt.includes("svg") ? "svg" : fileExt;
let filename = `${item.index}.${fileExt}`;
zipSubFoler.file(filename, img.split(",")[1], {base64: true});
console.log("正在转换",filename);
} catch (e) {
console.log("生成base64出错:",e)
}
})
promises.push(promise)
})
Promise.all(promises).then(() => {
console.log("zip started");
zipFolder.generateAsync({type: "blob"})
.then(function (content) {
console.log("zip success!");
// see FileSaver.js
saveAs(content, `${saveName}.zip`);
zipFolder.remove(saveName);
zipSubFoler = zipFolder.folder(saveName);
});
// zip.generateAsync({
// type: "blob"
// }).then(content => { // 生成二进制流
// saveAs(content, "photo.zip") // 利用file-saver保存文件
// })
})
};
//初始化样式
let initStyle = ()=>{
let addStyle = function (aCss) {
let head = document.getElementsByTagName('head')[0];
if (head) {
let style = document.createElement('style');
style.setAttribute('type', 'text/css');
style.textContent = aCss;
head.appendChild(style);
return style;
}
return null;
}
addStyle(`.viewer-close:before,.viewer-flip-horizontal:before,.viewer-flip-vertical:before,.viewer-fullscreen-exit:before,.viewer-fullscreen:before,.viewer-next:before,.viewer-one-to-one:before,.viewer-play:before,.viewer-prev:before,.viewer-reset:before,.viewer-rotate-left:before,.viewer-rotate-right:before,.viewer-zoom-in:before,.viewer-zoom-out:before{background-image:url("");background-repeat:no-repeat;background-size:280px;color:transparent;display:block;font-size:0;height:20px;line-height:0;width:20px}.viewer-zoom-in:before{background-position:0 0;content:"Zoom In"}.viewer-zoom-out:before{background-position:-20px 0;content:"Zoom Out"}.viewer-one-to-one:before{background-position:-40px 0;content:"One to One"}.viewer-reset:before{background-position:-60px 0;content:"Reset"}.viewer-prev:before{background-position:-80px 0;content:"Previous"}.viewer-play:before{background-position:-100px 0;content:"Play"}.viewer-next:before{background-position:-120px 0;content:"Next"}.viewer-rotate-left:before{background-position:-140px 0;content:"Rotate Left"}.viewer-rotate-right:before{background-position:-160px 0;content:"Rotate Right"}.viewer-flip-horizontal:before{background-position:-180px 0;content:"Flip Horizontal"}.viewer-flip-vertical:before{background-position:-200px 0;content:"Flip Vertical"}.viewer-fullscreen:before{background-position:-220px 0;content:"Enter Full Screen"}.viewer-fullscreen-exit:before{background-position:-240px 0;content:"Exit Full Screen"}.viewer-close:before{background-position:-260px 0;content:"Close"}.viewer-container{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;bottom:0;direction:ltr;font-size:0;left:0;line-height:0;overflow:hidden;position:absolute;right:0;top:0;-ms-touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.viewer-container::-moz-selection,.viewer-container ::-moz-selection{background-color:transparent}.viewer-container::selection,.viewer-container ::selection{background-color:transparent}.viewer-container:focus{outline:0}.viewer-container img{display:block;height:auto;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}.viewer-canvas{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.viewer-canvas>img{height:auto;margin:15px auto;max-width:90%!important;width:auto}.viewer-footer{bottom:0;left:0;overflow:hidden;position:absolute;right:0;text-align:center}.viewer-navbar{background-color:rgba(0,0,0,.5);overflow:hidden}.viewer-list{-webkit-box-sizing:content-box;box-sizing:content-box;height:50px;margin:0;overflow:hidden;padding:1px 0}.viewer-list>li{color:transparent;cursor:pointer;float:left;font-size:0;height:50px;line-height:0;opacity:.5;overflow:hidden;-webkit-transition:opacity .15s;transition:opacity .15s;width:30px}.viewer-list>li:focus,.viewer-list>li:hover{opacity:.75}.viewer-list>li:focus{outline:0}.viewer-list>li+li{margin-left:1px}.viewer-list>.viewer-loading{position:relative}.viewer-list>.viewer-loading:after{border-width:2px;height:20px;margin-left:-10px;margin-top:-10px;width:20px}.viewer-list>.viewer-active,.viewer-list>.viewer-active:focus,.viewer-list>.viewer-active:hover{opacity:1}.viewer-player{background-color:#000;bottom:0;cursor:none;display:none;right:0;z-index:1}.viewer-player,.viewer-player>img{left:0;position:absolute;top:0}.viewer-toolbar>ul{display:inline-block;margin:0 auto 5px;overflow:hidden;padding:6px 3px}.viewer-toolbar>ul>li{background-color:rgba(0,0,0,.5);border-radius:50%;cursor:pointer;float:left;height:24px;overflow:hidden;-webkit-transition:background-color .15s;transition:background-color .15s;width:24px}.viewer-toolbar>ul>li:focus,.viewer-toolbar>ul>li:hover{background-color:rgba(0,0,0,.8)}.viewer-toolbar>ul>li:focus{-webkit-box-shadow:0 0 3px #fff;box-shadow:0 0 3px #fff;outline:0;position:relative;z-index:1}.viewer-toolbar>ul>li:before{margin:2px}.viewer-toolbar>ul>li+li{margin-left:1px}.viewer-toolbar>ul>.viewer-small{height:18px;margin-bottom:3px;margin-top:3px;width:18px}.viewer-toolbar>ul>.viewer-small:before{margin:-1px}.viewer-toolbar>ul>.viewer-large{height:30px;margin-bottom:-3px;margin-top:-3px;width:30px}.viewer-toolbar>ul>.viewer-large:before{margin:5px}.viewer-tooltip{background-color:rgba(0,0,0,.8);border-radius:10px;color:#fff;display:none;font-size:12px;height:20px;left:50%;line-height:20px;margin-left:-25px;margin-top:-10px;position:absolute;text-align:center;top:50%;width:50px}.viewer-title{color:#ccc;display:inline-block;font-size:12px;line-height:1;margin:0 5% 5px;max-width:90%;opacity:.8;overflow:hidden;text-overflow:ellipsis;-webkit-transition:opacity .15s;transition:opacity .15s;white-space:nowrap}.viewer-title:hover{opacity:1}.viewer-button{background-color:rgba(0,0,0,.5);border-radius:50%;cursor:pointer;height:80px;overflow:hidden;position:absolute;right:-40px;top:-40px;-webkit-transition:background-color .15s;transition:background-color .15s;width:80px}.viewer-button:focus,.viewer-button:hover{background-color:rgba(0,0,0,.8)}.viewer-button:focus{-webkit-box-shadow:0 0 3px #fff;box-shadow:0 0 3px #fff;outline:0}.viewer-button:before{bottom:15px;left:15px;position:absolute}.viewer-fixed{position:fixed}.viewer-open{overflow:hidden}.viewer-show{display:block}.viewer-hide{display:none}.viewer-backdrop{background-color:rgba(0,0,0,.5)}.viewer-invisible{visibility:hidden}.viewer-move{cursor:move;cursor:-webkit-grab;cursor:grab}.viewer-fade{opacity:0}.viewer-in{opacity:1}.viewer-transition{-webkit-transition:all .3s;transition:all .3s}@-webkit-keyframes viewer-spinner{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes viewer-spinner{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}.viewer-loading:after{-webkit-animation:viewer-spinner 1s linear infinite;animation:viewer-spinner 1s linear infinite;border:4px solid hsla(0,0%,100%,.1);border-left-color:hsla(0,0%,100%,.5);border-radius:50%;content:"";display:inline-block;height:40px;left:50%;margin-left:-20px;margin-top:-20px;position:absolute;top:50%;width:40px;z-index:1}@media (max-width:767px){.viewer-hide-xs-down{display:none}}@media (max-width:991px){.viewer-hide-sm-down{display:none}}@media (max-width:1199px){.viewer-hide-md-down{display:none}}`)
addStyle('ul li{list-style-type:none;}');
}
let createButton = (name,event)=>{
let button = $(`<button style="margin-bottom:4px;border:1px solid #fff">${name}</button>`)
button.on("click",event)
toolBox.append(button)
return button
}
let initShowPages = ()=>{
imageViewer = $('<ul id ="viewer"></ul>');
convertPage = $('<div style="position:fixed;left:0;top:0px;right:0;bottom:0;width:100%;height:100%;overflow:auto;background-color:white;z-index:998"></div>');
toolBox = $('<div style="position:fixed;top:100px;right:30px;z-index:999;display:flex;flex-direction:column;"></div>')
switchBtn = createButton("切换显示",()=>{
if(convertPage){
let container = convertPage[0];
let status = container.style.display
if(status=="inline" || !status){
container.style.display = "none"
}else {
container.style.display = 'inline'
}
}
})
$("body").append(toolBox);
$("body").append(convertPage);
$("header").remove()
$(".header").remove()
setTimeout(() => {
new Viewer(document.getElementById('viewer'),{viewed(){}})
}, 3000);
}
setTimeout(function () {
var str3 = self.location.href.toString();
webHost = self.location.origin;
if(str3.indexOf("/plus/search")!=-1){
searchWebObject(webHost).loadThumbnail()
}else{
loadDetailPage();
}
},0)