Google Image Direct View

An different take of Google direct image viewer

目前为 2020-05-25 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name Google Image Direct View
  3. // @version 2.3
  4. // @namespace Google_Image_Direct_View
  5. // @description An different take of Google direct image viewer
  6. // @author navchandar
  7. // @include http*://www.google.*/*tbm=isch*
  8. // @include http*://google.*/*tbm=isch*
  9. // @include https://www.google.*/search?tbm=isch*
  10. // @include https://google.*/search?tbm=isch*
  11. // @include https://www.google.co.*/*tbm=isch*
  12. // @include https://google.co.*/*tbm=isch*
  13. // @run-at document-end
  14. // @license MIT
  15. // @grant none
  16. // @homepage https://github.com/navchandar
  17. // @copyright 2019, navchandar (https://openuserjs.org/users/navchandar)
  18. // @icon 
  19. // ==/UserScript==
  20.  
  21. function getElementsByXPath(xpath, parent) {
  22. let results = [];
  23. let query = document.evaluate(xpath, parent || document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
  24. for (let i = 0, length = query.snapshotLength; i < length; ++i) {
  25. results.push(query.snapshotItem(i));
  26. }
  27. return results
  28. };
  29.  
  30. function has(String, search) {
  31. try {
  32. if (String.indexOf(search) > -1) {
  33. return true;
  34. }
  35. }
  36. catch (err) {}
  37. return false;
  38. }
  39.  
  40. function UpdateElements(imgXpath) {
  41. var int = 0;
  42. var Img_items = getElementsByXPath(imgXpath);
  43. console.log(Img_items.length.toString() + " Image items found");
  44.  
  45. if (Img_items.length > 0) {
  46. var Link_items = getElementsByXPath(imgXpath + "//../../../a[@href] | " + imgXpath + "//../../a[@href]");
  47. console.log(Link_items.length.toString() + " Image items found");
  48.  
  49. for (var i = 0; i < Img_items.length; i++) {
  50. try {
  51. var src = Img_items[i].src;
  52. var uri = Link_items[i].href;
  53. if (uri != src) {
  54. int++;
  55. Link_items[i].title = "Image Loading... Wait..."
  56.  
  57. if (has(src, "data:image")) {
  58. //Link_items[i].href = src.replace(/^data:image\/[^;]+/, 'data:application/octet-stream');
  59. Link_items[i].href = src;
  60. Link_items[i].download = "Base64_Image.jpg";
  61.  
  62. }
  63. else if (has(src, "https://encrypted")) {
  64. var uri_enc = encodeURIComponent(uri);
  65. var uri_dec = decodeURIComponent(uri_enc);
  66.  
  67. }
  68. else {
  69. Link_items[i].href = src;
  70. }
  71.  
  72. }
  73. else {
  74. Link_items[i].title = "Image URL updated!"
  75. }
  76. }
  77. catch (err) {
  78. console.log(err);
  79. }
  80. }
  81. if (int > 0) {
  82. console.log("Updated " + int + " image links.");
  83. }
  84. }
  85. }
  86.  
  87. function addCssToDocument(css) {
  88. var style = document.createElement('style')
  89. style.innerText = css
  90. document.head.appendChild(style)
  91. }
  92.  
  93. (function () {
  94. 'use strict';
  95. var img1 = "//a[(contains(@jsaction, 'focus'))]/div/img[contains(@alt, 'Image') or contains(@alt, 'image')]";
  96. var img2 = "//a[(contains(@jsaction, 'focus'))]//img[contains(@alt, 'Image') or contains(@alt, 'image')]";
  97. var img3 = "//a[(contains(@jsaction, 'focus'))]//img[@jsaction]";
  98. setInterval(function () {
  99. UpdateElements(img1);
  100. UpdateElements(img2);
  101. UpdateElements(img3);
  102. }, 1000);
  103.  
  104. })();