Google Image Direct View

A different take on Google direct image viewer

当前为 2023-02-06 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Google Image Direct View
  3. // @version 3.4
  4. // @namespace Google_Image_Direct_View
  5. // @description A different take on Google direct image viewer
  6. // @author navchandar
  7. // @include https://www.google.tld/*tbm=isch*
  8. // @include https://www.google.tld/search?tbm=isch*
  9. // @include https://www.google.co.*/*tbm=isch*
  10. // @include https://www.google.co.*/search?tbm=isch*
  11. // @match https://lens.google.com/search*
  12. // @run-at document-end
  13. // @license MIT
  14. // @grant none
  15. // @homepage https://navchandar.github.io/
  16. // @homepage https://github.com/navchandar/
  17. // @homepageURL https://navchandar.github.io/
  18. // @contributionURL https://paypal.me/navchandar
  19. // @contributionAmount $1.00
  20. // @copyright 2019+, navchandar (https://openuserjs.org/users/navchandar)
  21. // @supportURL https://openuserjs.org/scripts/navchandar/Google_Image_Direct_View/issues
  22. // @setupURL https://openuserjs.org/install/navchandar/Google_Image_Direct_View.user.js
  23. // @icon 
  24. // ==/UserScript==
  25.  
  26. // If your device/extension is not running the script on Image search, try adding this above: // @include https://www.google.*
  27. // Check out this link: https://openuserjs.org/scripts/navchandar/Google_Image_Direct_View/issues/Alternative_to_tld_for_matching_domains_(for_non-Tampermonkey_users)_ for more details.
  28.  
  29. // Updated image xpath locator to work on Google Images and Google Lens
  30. var img_locator = "//c-wiz[@jsname]/parent::div[not(contains(@style, 'display: none'))]//a[(contains(@jsaction, 'focus'))]//img[not(contains(@src, 'gstatic.com/favicon'))] | //c-wiz[@jsname]/parent::div[not(contains(@style, 'display: none'))]//a//img[contains(@jsaction, 'load') and not(contains(@src, 'gstatic.com/favicon'))]";
  31. var lens_locator1 = "//a/div//img[not(contains(@alt, 'tag') or contains(@alt, 'domain'))]";
  32. var lens_locator2 = "//a/div/img";
  33.  
  34. function getElementsByXPath(xpath, parent) {
  35. let results = [];
  36. let query = document.evaluate(xpath, parent || document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
  37. for (let i = 0, length = query.snapshotLength; i < length; ++i) {
  38. results.push(query.snapshotItem(i));
  39. }
  40. return results;
  41. }
  42.  
  43. function has(String, search) {
  44. try {
  45. if (String.indexOf(search) > -1) {
  46. return !0
  47. }
  48. }
  49. catch (err) {}
  50. return !1
  51. }
  52.  
  53. function is_lens() {
  54. return has(window.location.href, "lens.google.")
  55. }
  56.  
  57. function get_img_locator() {
  58. let imgXpath = "";
  59. if (is_lens()) {
  60. imgXpath = lens_locator1 + " | " + lens_locator2;
  61. }
  62. else {
  63. imgXpath = img_locator;
  64. }
  65. return imgXpath;
  66. }
  67.  
  68. function get_img_link_locator() {
  69. let linkXpath = "";
  70. if (is_lens()) {
  71. linkXpath = lens_locator2 + "//../../../a[@href] | " + lens_locator1 + "//../../../../../a[@href]";
  72. }
  73. else {
  74. let img_xp = "(" + img_locator + ")";
  75. linkXpath = img_xp + "//../../../a[@href] | " + img_xp + "//../../a[@href]"
  76. }
  77. return linkXpath;
  78. }
  79.  
  80. function UpdateElements() {
  81. var int = 0;
  82. let imgXpath = get_img_locator();
  83. let linkXpath = get_img_link_locator()
  84. var Img_items = getElementsByXPath(imgXpath);
  85. console.log(Img_items.length.toString() + " Image items found");
  86.  
  87. if (Img_items.length > 0) {
  88. var Link_items = getElementsByXPath(linkXpath);
  89. console.log(Link_items.length.toString() + " link items found");
  90.  
  91. for (var i = 0; i < Img_items.length; i++) {
  92. try {
  93. console.log(Link_items[i].jsaction);
  94. var src = Img_items[i].src;
  95. var uri = Link_items[i].href;
  96.  
  97. if (uri != src) {
  98. int++;
  99. Link_items[i].title = "Image Loading... Wait..."
  100.  
  101. if (has(src, "data:image")) {
  102. Link_items[i].href = src;
  103. Link_items[i].download = "Base64_Image.jpg";
  104. }
  105. else if (has(src, "https://encrypted") && is_lens()) {
  106. Link_items[i].href = src;
  107. Link_items[i].removeAttribute('jsaction');
  108. }
  109. else {
  110. Link_items[i].href = src;
  111. console.log(Link_items[i].jsaction);
  112. Link_items[i].removeAttribute('jsaction');
  113. }
  114. }
  115. else {
  116. Link_items[i].title = "Image URL updated!"
  117. }
  118. }
  119. catch (err) {
  120. console.log(err);
  121. }
  122. }
  123. if (int > 0) {
  124. console.log("Updated " + int + " image links.");
  125. }
  126. }
  127. }
  128.  
  129. function addCssToDocument(css) {
  130. var style = document.createElement('style');
  131. style.innerText = css;
  132. document.head.appendChild(style);
  133. }
  134.  
  135. (function () {
  136. 'use strict';
  137. setInterval(function () {
  138. UpdateElements();
  139. }, 500);
  140. })()