HTML5 player for Metacritic

Avoid having to use Flash Player to watch videos. No ads.

2015-11-19 기준 버전입니다. 최신 버전을 확인하세요.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name        HTML5 player for Metacritic
// @namespace   https://greasyfork.org/users/4813-swyter
// @description Avoid having to use Flash Player to watch videos. No ads.
// @match       http://www.metacritic.com/*
// @version     2015.11.19
// @noframes
// @icon        https://i.imgur.com/CecLLKu.png
// @grant       none
// @run-at      document-start
// ==/UserScript==

/* wait until the page is ready for the code snipped to run */
document.addEventListener('DOMContentLoaded', function()
{
  window.MetaC = window.MetaC || {};
  window.MetaC.CANPlayer = window.MetaC.CANPlayer || {};

  /* override the flash video function and call it a day */
  Object.defineProperty(window.MetaC.CANPlayer, 'initPlayer',
  {
    configurable: false,
    writable: false,
    value: function(elem, width, height, options)
    {
      console.info("check overriden! video arguments =>", arguments);

      v = document.createElement("video");

      v.width = width;
      v.height = height;
      v.src = options[0].assetURL;

      v.poster = options[0].prevImg;
      v.controls = 'true';

      /* replace the old SWF Flash object with it, voilà */
      elem = document.getElementById(elem);
      elem.parentNode.replaceChild(v, elem);

      console.log("video replaced =>", v, elem);
    }
  });
});