iMDB Large Images

Large iMDB images when you hover over them.

目前为 2017-03-02 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name iMDB Large Images
  3. // @version 1.0.11
  4. // @description Large iMDB images when you hover over them.
  5. // @namespace https://greasyfork.org/en/scripts/11249-imdb-large-images
  6. // @homepage https://greasyfork.org/en/scripts/11249-imdb-large-images
  7. // @match http://imdb.com/*
  8. // @match https://imdb.com/*
  9. // @match http://*.imdb.com/*
  10. // @match https://*.imdb.com/*
  11. // @icon 
  12. // @require http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js
  13. // @grant none
  14. // ==/UserScript==
  15.  
  16. this.$ = this.jQuery = jQuery.noConflict(true);
  17.  
  18. /*!
  19. * hoverIntent v1.8.0 // 2014.06.29 // jQuery v1.9.1+
  20. * http://cherne.net/brian/resources/jquery.hoverIntent.html
  21. *
  22. * You may use hoverIntent under the terms of the MIT license. Basically that
  23. * means you are free to use hoverIntent as long as this header is left intact.
  24. * Copyright 2007, 2014 Brian Cherne
  25. */
  26. (function($){$.fn.hoverIntent=function(handlerIn,handlerOut,selector){var cfg={interval:100,sensitivity:6,timeout:0};if(typeof handlerIn==="object"){cfg=$.extend(cfg,handlerIn)}else{if($.isFunction(handlerOut)){cfg=$.extend(cfg,{over:handlerIn,out:handlerOut,selector:selector})}else{cfg=$.extend(cfg,{over:handlerIn,out:handlerIn,selector:handlerOut})}}var cX,cY,pX,pY;var track=function(ev){cX=ev.pageX;cY=ev.pageY};var compare=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);if(Math.sqrt((pX-cX)*(pX-cX)+(pY-cY)*(pY-cY))<cfg.sensitivity){$(ob).off("mousemove.hoverIntent",track);ob.hoverIntent_s=true;return cfg.over.apply(ob,[ev])}else{pX=cX;pY=cY;ob.hoverIntent_t=setTimeout(function(){compare(ev,ob)},cfg.interval)}};var delay=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);ob.hoverIntent_s=false;return cfg.out.apply(ob,[ev])};var handleHover=function(e){var ev=$.extend({},e);var ob=this;if(ob.hoverIntent_t){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t)}if(e.type==="mouseenter"){pX=ev.pageX;pY=ev.pageY;$(ob).on("mousemove.hoverIntent",track);if(!ob.hoverIntent_s){ob.hoverIntent_t=setTimeout(function(){compare(ev,ob)},cfg.interval)}}else{$(ob).off("mousemove.hoverIntent",track);if(ob.hoverIntent_s){ob.hoverIntent_t=setTimeout(function(){delay(ev,ob)},cfg.timeout)}}};return this.on({"mouseenter.hoverIntent":handleHover,"mouseleave.hoverIntent":handleHover},cfg.selector)}})(jQuery);
  27.  
  28. $(document).ready(function() {
  29.  
  30. var cssCode = "\
  31. #largeImagePopover { \
  32. position: absolute; \
  33. box-shadow: 0 0 15px #000; \
  34. cursor: pointer; \
  35. z-index: 1000; \
  36. } \
  37. ";
  38. var styleElement = document.createElement("style");
  39. styleElement.type = "text/css";
  40. if (styleElement.styleSheet) {
  41. styleElement.styleSheet.cssText = cssCode;
  42. } else {
  43. styleElement.appendChild(document.createTextNode(cssCode));
  44. }
  45. document.getElementsByTagName("head")[0].appendChild(styleElement);
  46.  
  47. var hoverInFunction = function (e) {
  48.  
  49. var hoveredImage = this.src ? this : $(this).find('img').get(0);
  50. hoveredImage.style.cursor = 'progress';
  51.  
  52. $('div#largeImagePopover, div.largeImagePopover').remove();
  53. $("body").css("overflow", "auto");
  54.  
  55. // setup the large image
  56. var popImage = document.createElement("img");
  57. var src = hoveredImage.src;
  58. src = src.replace(/_V1\.?.*?_\./g,"_V1_.");
  59. src = src.replace(/_V1_?\.jpg/,"_V1_SY"+window.innerHeight+"_.jpg");
  60.  
  61. popImage.src = src
  62. popImage.alt = hoveredImage.alt;
  63. popImage.border = 0;
  64.  
  65. // setup the image link
  66. var popLink = document.createElement("a");
  67. popLink.href = $(hoveredImage).parents('a').attr('href');
  68. popLink.appendChild(popImage);
  69.  
  70. // setup the image div
  71. var popDiv = document.createElement("div");
  72. popDiv.id = 'largeImagePopover';
  73. popDiv['class'] = 'largeImagePopover';
  74. popDiv.appendChild(popLink);
  75. $(popDiv).hide();
  76.  
  77. // attach events to new image
  78. $(popImage).mouseout( function() {
  79. $(popDiv).remove();
  80. });
  81. $(popImage).css('cursor','crosshair');
  82.  
  83. $(popImage).load( function() {
  84. // these assignments may differ per browser
  85. var pageXOffset = window.pageXOffset;
  86. var pageYOffset = window.pageYOffset;
  87. var innerWidth = window.innerWidth;
  88. var innerHeight = window.innerHeight;
  89. var mouseX = e.pageX;
  90. var mouseY = e.pageY;
  91.  
  92. // shrink image if wider than screen
  93. if(popImage.width > innerWidth-17) {
  94. var tmpW = popImage.width;
  95. popImage.width = Math.min(popImage.width,innerWidth-17);
  96. popImage.height = (popImage.width/tmpW) * popImage.height;
  97. }
  98. if(popImage.height > innerHeight) {
  99. var tmpH = popImage.height;
  100. popImage.height = Math.min(popImage.height,innerHeight);
  101. popImage.width = (popImage.height/tmpH) * popImage.width;
  102. }
  103.  
  104. // center image on mouse cursor
  105. var x = mouseX - parseInt(popImage.width/2);
  106. var y = mouseY - parseInt(popImage.height/2);
  107.  
  108. // move image down and right if off screen to the left or top
  109. x = Math.max(x,pageXOffset);
  110. y = Math.max(y,pageYOffset);
  111.  
  112. // move image up or left if off screen to the right or bottom
  113. x = Math.min(x, pageXOffset + innerWidth - 17 - popImage.width);
  114. y = Math.min(y, pageYOffset + innerHeight - popImage.height);
  115.  
  116. // move image down and right if off screen to the left or top
  117. x = Math.max(x,pageXOffset);
  118. y = Math.max(y,pageYOffset);
  119.  
  120. $(popImage.parentNode.parentNode).css('left',x);
  121. $(popImage.parentNode.parentNode).css('top',y);
  122. $(popImage.parentNode.parentNode).show();
  123.  
  124. hoveredImage.style.cursor = 'crosshair';
  125. });
  126.  
  127. $('body').append($(popDiv));
  128. };
  129.  
  130. $(document).keyup(function(e) {
  131. if (e.keyCode == 27) {
  132. $('div#largeImagePopover, div.largeImagePopover').remove();
  133. }
  134. });
  135. function checkImages() {
  136. $("img[src*='_V1']").not("img[src*='_ZA']").not(".imageDone").each(function() {
  137. $(this).addClass('imageDone').css('cursor','crosshair').hoverIntent( hoverInFunction, function(){} );
  138. });
  139. window.setTimeout(checkImages, 1000);
  140. }
  141. checkImages();
  142.  
  143. });