您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
鼠标悬停在 flash 视频上会出现一个按钮,点击后可放大浮动在页面上。
- // ==UserScript==
- // @author yansyrs
- // @name PopupFlash
- // @namespace http://opera.im/archives/pop-up-flash/
- // @description 鼠标悬停在 flash 视频上会出现一个按钮,点击后可放大浮动在页面上。
- // @version v1.1.6
- // @date 2013-10-18
- // @include *
- // ==/UserScript==
- (function(storage){
- /* -------------------------------------------- 设置开始 ------------------------------------------*/
- // 悬停在视频上的按钮尺寸,单位为像素
- var POPUP_ICON_SIZE = 26;
- // 无保存值时,浮动的 FLASH 的默认尺寸,默认长和宽为浏览器页面大小的 70%
- var POPUP_FLASH_SIZE = 70;
- // 浮动 FLASH 的最小宽度,单位为像素
- var POPUP_FLASH_MIN_WIDTH = 640;
- // 浮动 FLASH 的最小高度,单位为像素
- var POPUP_FLASH_MIN_HEIGHT = 480;
- // 出现在菜单上的尺寸列表,name 是列表项文字,width 是宽度,height 是高度。单位是像素。
- // 注:width 与 height 任意一值超过可视页面的宽/高时,则该菜单不显示
- var POPUP_FLASH_SIZE_LIST =
- [
- {name: '初始默认值', width: 0, height: 0}, // 此项为第一位且不删除
- {name: '800 x 600', width: 800, height: 600},
- {name: '854 x 480 [宽]', width: 854, height: 480},
- {name: '1024 x 768', width: 1024, height: 768},
- {name: '1280 x 720 [宽]', width: 1280, height: 720},
- ];
- // 黑色背景的不透明度,0 为全透,1 为不透
- var BACKGROUND_OPACITY = 0.8;
- // 拖拽边缘调整尺寸时,在何处显示尺寸大小
- // 可选值:title、statusbar、both、disable(分别代表“标题栏”、“状态栏”、“标题栏和状态栏”以及“不显示”)
- // 注:Opera 的 JavaScript 选项中必须勾选“允许更改状态域”才能使状态栏的修改生效。
- var SHOW_RESIZE_INFO = 'both';
- // 点击背景关闭浮动的 FLASH,可选值:"NONE_CLICK"、"CLICK"、"DOUBLE_CLICK"
- var CLICK_BLANK_TO_CLOSE = 'CLICK';
- // 白名单列表,判断时优先级最高,只要出现该关键字就认为是视频
- // 可设置多个,用逗号分隔,使用小写
- // 规则:如果 flash 代码的 id、class、name、src、data、flashvars 任一属性中出现下列关键词,则认为是视频
- var WHITE_LIST_KEYWORD_IMPORTANT = ['ytimg'];
- // 白名单列表,优先级最低,如果在黑名单中已经排除,那么即使在白名单内也有相关关键字,也不会认为是视频
- var WHITE_LIST_KEYWORD = ['player', 'video', 'tudou.com', 'viddler', 'youtube'];
- // 黑名单列表,可设置多个,用逗号分割,使用小写
- // 如果 flash 代码的 id、class、name、src、data、flashvars 任一属性中出现下列关键词,则认为不是视频
- // 注:可将没有通用关键词的网站域名列入关键词内,如 xiami.com。同一个关键词在黑白名单都出现时,优先黑名单。
- var BLACK_LIST_KEYWORD = ['mp3', 'music', 'xiami.com', 'adplayer'];
- // 尺寸过滤,如果宽与高都小于下面的值,则认为不是视频。单位为像素。
- var FLASH_SIZE_FILTER = {width: 320, height: 240};
- // 拖动窗口时,该值越大,占用 CPU 越小,但同时也越不平滑。
- var PLAYER_MOUSE_MOVE_FILTER = 2;
- /* -------------------------------------------- 设置结束 ------------------------------------------*/
- var picData = {
- popup_icon: '',
- popup_icon_reload: '',
- option: '',
- close: '',
- pin: '',
- save: '',
- player_bg: '',
- loading: '',
- };
- var styleText = '\
- .fv_PopupFlash_body_firefox object, \
- .fv_PopupFlash_body_firefox embed{ \
- display: none !important; \
- } \
- #fv_popup_player, \
- #fv_popup_player object, \
- #fv_popup_player embed, \
- object[fv_is_parent_object], \
- object[fv_is_parent_object] object, \
- object[fv_is_parent_object] embed{ \
- display: block !important; \
- } \
- #fv_popup_icon{ \
- width: ' + POPUP_ICON_SIZE + 'px; height: ' + POPUP_ICON_SIZE + 'px; \
- position: absolute; \
- background-image: url("' + picData.popup_icon + '"); \
- background-color: black; \
- background-size: 100% 100%; \
- z-index: 999999; \
- cursor: pointer; \
- } \
- #fv_popup_icon.reload{ \
- background-image: url("' + picData.popup_icon_reload + '"); \
- } \
- #fv_PopupFlash{ \
- background-color: rgba(0, 0, 0, ' + BACKGROUND_OPACITY + '); \
- position: fixed; \
- left: 0px; top: 0px; \
- width: 100%; \
- height: 100%; \
- z-index: 999998; \
- text-align: center; \
- } \
- #fv_PopupFlash.move{ \
- text-align: left; \
- } \
- #fv_popup_container{ \
- position: relative; \
- float: none; \
- z-index: 999999; \
- box-sizing: content-box; \
- -moz-box-sizing: content-box; \
- padding: 11px; \
- display: inline-block; \
- border-radius: 5px; \
- box-shadow: 0px 0px 30px black; \
- background-color: white; \
- background-image: url("' + picData.player_bg +'"); \
- background-repeat: no-repeat; \
- background-position:center; \
- line-height: 0px; \
- } \
- #fv_popup_player.noReload, \
- #fv_popup_player.noReload > embed{ \
- padding: 0px !important; \
- margin: 0px !important; \
- border: 0px !important; \
- z-index: 1000000 !important; \
- position: fixed !important; \
- display: block !important; \
- } \
- #fv_popup_player_parent.noReload{ \
- z-index: auto !important; \
- position: absolute !important; \
- overflow: visible !important; \
- opacity: 1 !important; \
- } \
- .fv_popup_player_forefather.noReload{ \
- z-index: auto !important; \
- opacity: 1 !important; \
- } \
- #fv_popup_option{ \
- width: 32px; \
- height: 32px; \
- background-image: url("' + picData.option + '"); \
- cursor: pointer; \
- position: absolute; \
- top: -16px; \
- left: -16px; \
- z-index: 1; \
- }\
- #fv_popup_option:hover{ \
- border-radius: 16px; \
- background-image: url("' + picData.close + '"); \
- } \
- #fv_popup_menu{ \
- width: auto; \
- height: auto; \
- display: none; \
- opacity: 0; \
- background-color: white; \
- position: absolute; \
- top: 3px; \
- left: 3px; \
- border: 2px dashed rgb(150, 150, 150); \
- box-shadow: inset 0px 0px 10px rgb(150, 150, 150); \
- text-align: left; \
- line-height: 18px; \
- font-size: 12px; \
- color: black; \
- padding: 5px 10px 5px 25px; \
- transition: opacity 0.7s ease; \
- -o-transition: opacity 0.7s ease; \
- } \
- #fv_popup_option:hover + #fv_popup_menu{ \
- display: inline; \
- opacity: 1; \
- } \
- #fv_popup_menu:hover{ \
- display: inline; \
- opacity: 1; \
- } \
- #fv_popup_menu .fv_menu_item_hide{ \
- display: none; \
- } \
- #fv_popup_menu ul{ \
- padding: 0px; \
- margin: 0px; \
- } \
- #fv_popup_menu li{ \
- list-style: disc outside; \
- } \
- #fv_popup_menu li:hover{ \
- background-color: rgb(234, 234, 234); \
- cursor: pointer; \
- } \
- #fv_popup_menu .fv_popup_pin{ \
- float: right; \
- width: 14px; \
- height: 14px; \
- margin-left: 5px; \
- margin-top: 1px; \
- background-image: url("' + picData.pin + '"); \
- background-color: transparent; \
- background-size: 100% 100%; \
- visibility: hidden; \
- } \
- #fv_popup_menu #fv_pin_press.fv_popup_pin{ \
- background-color: rgb(220, 220, 220); \
- visibility: visible; \
- } \
- #fv_popup_menu .fv_popup_save{ \
- float: right; \
- width: 14px; \
- height: 14px; \
- margin-left: 5px; \
- margin-top: 1px; \
- background-image: url("' + picData.save + '"); \
- background-size: 100% 100%; \
- visibility: hidden; \
- } \
- #fv_popup_menu .fv_menu_item_normal > span{ \
- color: #1F1F1F; \
- font-weight: normal; \
- } \
- #fv_popup_menu .fv_menu_item_selected > span{ \
- color: black; \
- font-weight: bold; \
- } \
- #fv_popup_menu li:hover > .fv_popup_pin{ \
- visibility: visible; \
- } \
- #fv_popup_menu li:hover > .fv_popup_save{ \
- visibility: visible; \
- } \
- #fv_popup_option.noReload{ \
- position: fixed; \
- z-index: 1000002; \
- } \
- #fv_popup_menu.noReload{ \
- position: fixed; \
- z-index: 1000001; \
- } \
- ';
- var resizeMouseDwn = {x: 0, y: 0};
- var resizeFlag = false;
- var resizeBegin = false;
- var resizeEdge = 'EDGE_NONE';
- var edgeLeft = 'EDGE_NONE';
- var edgeTop = 'EDGE_NONE';
- var flashPreSize = null;
- var flashFinalSize = {w: 0, h: 0};
- var mouseMoveCount = 0;
- var adjustPreX = 0;
- var adjustPreY = 0;
- var adjustX = 0;
- var adjustY = 0;
- var titleSaved = '';
- //for move
- var closeLock = false;
- var playerMoved = false;
- var playerMoving = false;
- //for iframe
- var loadingTimer = 0;
- var randomName = 'none';
- var randomName2 = 'none';
- var savedIframeName = null;
- var topSavedIframeName = null;
- var topSavedObj = null;
- var parentWndWidth = 0;
- var parentWndHeight = 0;
- //for no reload
- var orgStyle = new Object();
- var orgForefather = [];
- //for alt, ctrl & shift key
- var funcKeyPress = false;
- function _addStyle(str){
- var styleObj = _createElement('style');
- styleObj.textContent = str;
- $('head').appendChild(styleObj);
- }
- function _getObjTag(obj){
- return obj ? obj.nodeName.toLowerCase() : '';
- }
- function $(str){
- return document.querySelector(str);
- }
- function $$(str){
- return document.querySelectorAll(str);
- }
- function sendToAllFrames(data){
- var f = window.frames;
- for(var i = 0; i < f.length; i++){
- f[i].postMessage(data, '*');
- }
- }
- function _createNodeByString(str){
- var tempDiv = document.createElement('div');
- tempDiv.innerHTML = str;
- var node = tempDiv.firstChild.cloneNode(true);
- delete(tempDiv);
- return node;
- }
- function _getStorageItem(name){
- if(window.opera){
- if(typeof storage != 'undefined'){
- var data = storage.getItem(name);
- if(data != null){
- return JSON.parse(data);
- }
- }
- }
- else if(typeof GM_getValue != 'undefined'){
- var data = GM_getValue(name);
- if(data != null){
- return JSON.parse(data);
- }
- }
- return null;
- }
- function _setStorageItem(name, data){
- if(window.opera){
- if( (typeof storage) != 'undefined' ){
- storage.setItem(name, JSON.stringify(data));
- return true;
- }
- else{
- alert('请先给 opera:config#PersistentStorage|UserJSStorageQuota 设置一个值 (单位为 kB),然后再刷新试试。');
- return false;
- }
- }
- else if(typeof GM_setValue != 'undefined'){
- GM_setValue(name, JSON.stringify(data));
- return true;
- }
- else{
- alert('存储本地数据失败');
- return false;
- }
- }
- function _createElement(tag, id, classId){
- var obj = document.createElement(tag);
- id && (obj.id = id);
- classId && (obj.className = classId);
- return obj;
- }
- function _getElementXY(ele){
- if(ele.getBoundingClientRect){
- return {
- x : ele.getBoundingClientRect().left + Math.max(document.documentElement.scrollLeft, document.body.scrollLeft),
- y : ele.getBoundingClientRect().top + Math.max(document.documentElement.scrollTop, document.body.scrollTop)
- }
- }
- else{
- var i = ele.offsetLeft, j = ele.offsetTop;
- var temp_node = ele;
- while(temp_node.offsetParent){
- temp_node = temp_node.offsetParent;
- i += temp_node.offsetLeft;
- j += temp_node.offsetTop;
- }
- temp_node = ele;
- while(temp_node.parentNode && temp_node.parentNode.tagName != 'BODY'){
- temp_node = temp_node.parentNode;
- i -= temp_node.scrollLeft;
- j -= temp_node.scrollTop;
- }
- return {
- x : i,
- y : j
- }
- }
- }
- function _getStyleSize(obj){
- var width = obj.style.width || window.getComputedStyle(obj, null).width;
- var height = obj.style.height || window.getComputedStyle(obj, null).height;
- return { w: parseInt(width), h: parseInt(height) };
- }
- function _getStyleXY(obj){
- var left = obj.style.left || window.getComputedStyle(obj, null).left;
- var top = obj.style.top || window.getComputedStyle(obj, null).top;
- return { x: parseInt(left), y: parseInt(top) };
- }
- function _saveAndSetObjAttri(obj, attr, newValue){
- if(obj.getAttribute(attr)){
- obj.setAttribute('_' + attr, obj.getAttribute(attr));
- }
- obj.setAttribute(attr, newValue);
- }
- function _restoreObjAttr(obj, attr){
- obj.removeAttribute(attr);
- if(obj.getAttribute('_' + attr)){
- obj.setAttribute(attr, obj.getAttribute('_' + attr));
- obj.removeAttribute('_' + attr);
- }
- }
- function _saveAndSetObjPositionSize(obj){
- var pos = _getElementXY(obj);
- var style_str = obj.getAttribute('style') || '';
- style_str.replace(/([^-]|^)(left|top|right|bottom|width|height)[^-:]*:[^;]+(;|$)/ig, '$1').replace(/( ){2,}/g, ' ');
- if(style_str != ''){
- style_str += ' ';
- }
- style_str += 'left: ' + pos.x + 'px !important; top: ' + pos.y + 'px !important; width: ' + obj.offsetWidth + 'px !important; height: ' + obj.offsetHeight + 'px !important;';
- _saveAndSetObjAttri(obj, 'style', style_str);
- }
- function _restoreObjPositionSize(obj){
- _restoreObjAttr(obj, 'style');
- }
- function _setTransition(obj, type){
- if(type == 'none'){
- obj.style.setProperty('transition-property', 'none', null);
- obj.style.setProperty('-o-transition-property', 'none', null);
- obj.style.setProperty('-moz-transition-property', 'none', null);
- }
- else{
- obj.style.setProperty('transition', type, null);
- obj.style.setProperty('-o-transition', type, null);
- obj.style.setProperty('-moz-transition', type, null);
- }
- }
- function _getDefaultWidth(){
- return Math.max(window.innerWidth * POPUP_FLASH_SIZE / 100, POPUP_FLASH_MIN_WIDTH);
- }
- function _getDefaultHeight(){
- return Math.max(window.innerHeight * POPUP_FLASH_SIZE / 100, POPUP_FLASH_MIN_HEIGHT);
- }
- function _getMaxWidth(){
- return window.innerWidth - 50;
- }
- function _getMaxHeight(){
- return window.innerHeight - 30;
- }
- function _saveTitle(){
- titleSaved = document.title;
- }
- function _restoreTitle(){
- document.title = titleSaved;
- }
- function _setTitle(str){
- document.title = str;
- }
- function check_bound(x, y, ox, oy, ow, oh){
- return (x >= ox) && (x <= (ox + ow)) && (y >= oy) && (y <= (oy + oh));
- }
- function check_obj_edge(obj, x, y){
- var objPos = _getElementXY(obj);
- var objSize = {w: obj.offsetWidth, h: obj.offsetHeight};
- if(check_bound(x, y, objPos.x, objPos.y, objSize.w, objSize.h) == false /* div 外侧 */
- || check_bound(x, y, objPos.x + 8, objPos.y + 8, objSize.w - 16, objSize.h - 16) == true /* flash 内 */){
- return 'EDGE_NONE';
- }
- if( (Math.abs(x - objPos.x) <= 8 || Math.abs(objPos.x + objSize.w - x) <= 8)
- && (Math.abs(y - objPos.y) >= 25 && Math.abs(objPos.y + objSize.h - y) >= 25) ){
- return 'EDGE_LEFT_RIGHT';
- }
- else if( (Math.abs(y - objPos.y) <= 8 || Math.abs(objPos.y + objSize.h - y) <= 8)
- && (Math.abs(x - objPos.x) >= 25 && Math.abs(objPos.x + objSize.w - x) >= 25) ){
- return 'EDGE_TOP_BOTTOM';
- }
- else{
- return 'EDGE_CORNER';
- }
- }
- function set_parent_no_reload(obj){
- var temp = obj;
- var parentFind = false;
- while((temp = temp.parentNode) && _getObjTag(temp) != 'body'){
- var zIndex = temp.style.zIndex || window.getComputedStyle(temp, null).zIndex;
- if(_getObjTag(temp) == 'object'){
- _saveAndSetObjAttri(temp, 'fv_is_parent_object', 'true');
- }
- if(zIndex != 'auto' && parentFind == false){
- //放在设置 id 与 class 前
- _saveAndSetObjPositionSize(temp);
- _saveAndSetObjAttri(temp, 'id', 'fv_popup_player_parent');
- _saveAndSetObjAttri(temp, 'class', 'noReload');
- parentFind = true;
- }
- else if(zIndex != 'auto'){
- orgForefather.push(temp);
- _saveAndSetObjAttri(temp, 'class', 'fv_popup_player_forefather noReload');
- }
- }
- }
- function recover_parent_no_reload(){
- var po = $$('[fv_is_parent_object]');
- for(var i = 0; i < po.length; i ++){
- _restoreObjAttr(po[i], 'fv_is_parent_object');
- }
- var orgTargetObj = document.getElementById('fv_popup_player_parent');
- if(orgTargetObj != null){
- _restoreObjAttr(orgTargetObj, 'id');
- _restoreObjAttr(orgTargetObj, 'class');
- _restoreObjPositionSize(orgTargetObj);
- orgTargetObj = null;
- }
- while(orgForefather.length != 0){
- var obj = orgForefather.pop();
- _restoreObjAttr(obj, 'class');
- }
- }
- function create_black_background(obj){
- if(!$('#fv_PopupFlash')){
- if(!window.opera){
- document.body.className += ' fv_PopupFlash_body_firefox';
- }
- if(obj){
- var embed = obj.getElementsByTagName('embed');
- obj.style.visibility = 'hidden';
- if(embed[0]){
- embed[0].style.visibility = 'hidden';
- }
- save_and_hide_original_player_no_reload(obj);
- set_parent_no_reload(obj);
- }
- var div = _createElement('div', 'fv_PopupFlash');
- div.innerHTML = '.';
- document.body.appendChild(div);
- if(CLICK_BLANK_TO_CLOSE == 'CLICK' || CLICK_BLANK_TO_CLOSE == 'DOUBLE_CLICK'){
- var evtType = (CLICK_BLANK_TO_CLOSE == 'CLICK') ? 'click' : 'dblclick';
- div.addEventListener(evtType, function(e){
- if(e.target == this){
- var close = $('#fv_popup_option');
- closeLock = false;
- if(close) close.click();
- }
- }, false);
- }
- }
- }
- function del_black_background(obj){
- clearInterval(loadingTimer);
- if(!window.opera){
- document.body.className = document.body.className.replace(' fv_PopupFlash_body_firefox', '');
- }
- var bk = $('#fv_PopupFlash');
- if(bk){
- document.body.removeChild(bk);
- }
- recover_parent_no_reload();
- if(obj){
- recover_original_player_no_reload(obj);
- }
- }
- function _setObjSize(obj, w, h){
- var container = document.getElementById('fv_popup_container');
- if(w){
- if(!resizeFlag){
- obj.setAttribute('width', w);
- obj.style.setProperty('width', w + 'px', 'important');
- }
- if(container){//if(container && container.className == 'noReload'){
- container.style.width = w + 'px';
- }
- }
- if(h){
- if(!resizeFlag){
- obj.setAttribute('height', h);
- obj.style.setProperty('height', h + 'px', 'important');
- }
- if(container){//if(container && container.className == 'noReload'){
- container.style.height = h + 'px';
- }
- }
- }
- function resize_popup_flash(obj, w, h){
- var embed = obj.getElementsByTagName('embed');
- var div = document.getElementById('fv_popup_container');
- if(w){
- w = (w >= _getMaxWidth()) ? _getMaxWidth() : w;
- w = (w < POPUP_FLASH_MIN_WIDTH) ? POPUP_FLASH_MIN_WIDTH : w;
- _setObjSize(obj, Math.round(w), 0);
- if(embed[0]){
- _setObjSize(embed[0], Math.round(w), 0);
- }
- }
- if(h){
- h = (h >= _getMaxHeight()) ? _getMaxHeight() : h;
- h = (h < POPUP_FLASH_MIN_HEIGHT) ? POPUP_FLASH_MIN_HEIGHT : h;
- _setObjSize(obj, 0, Math.round(h));
- if(embed[0]){
- _setObjSize(embed[0], 0, Math.round(h));
- }
- if(div && playerMoved == false){
- var height = (div.className == 'noReload') ? div.offsetHeight : _getStyleSize(div).h;
- div.style.top = (window.innerHeight - height) / 2 + 'px';
- }
- }
- }
- function resize_popup_flash_by_drag(obj, w, h, edgeLeft, edgeTop){
- var div = document.getElementById('fv_popup_container');
- var divSize = _getStyleSize(div), divPos = _getStyleXY(div);
- var divSizeAfter = null;
- resize_popup_flash(obj, w, h);
- flashFinalSize.w = w;
- flashFinalSize.h = h;
- divSizeAfter = _getStyleSize(div);
- if(SHOW_RESIZE_INFO == 'title' || SHOW_RESIZE_INFO == 'both'){
- _setTitle('[ ' + divSizeAfter.w + ' x ' + divSizeAfter.h + ' ]');
- }
- if(SHOW_RESIZE_INFO == 'statusbar' || SHOW_RESIZE_INFO == 'both'){
- window.status = '[ ' + divSizeAfter.w + ' x ' + divSizeAfter.h + ' ]';
- }
- if(!playerMoved){
- return;
- }
- if(edgeLeft == 'EDGE_LEFT'){
- div.style.left = divPos.x - (divSizeAfter.w - divSize.w) + 'px';
- }
- if(edgeTop == 'EDGE_TOP'){
- div.style.top = divPos.y - (divSizeAfter.h - divSize.h) + 'px';
- }
- }
- function fill_popup_option_menu(){
- var i = 0;
- var htmlText = '<ul>';
- var customSize = null;
- var selected = _getStorageItem('fv_saved_idx') ? _getStorageItem('fv_saved_idx') : 0;
- for(i = 0; i < POPUP_FLASH_SIZE_LIST.length; i++){
- htmlText += '<li class="fv_menu_item_normal';
- if(POPUP_FLASH_SIZE_LIST[i].width >= _getMaxWidth()
- || POPUP_FLASH_SIZE_LIST[i].height >= _getMaxHeight()){
- htmlText += ' fv_menu_item_hide';
- }
- htmlText += '"><span id="fv_pin_normal" class="fv_popup_pin"></span><span>' + POPUP_FLASH_SIZE_LIST[i].name + '</span></li>';
- }
- htmlText += '<li id="fv_menu_item_custom" class="fv_menu_item_normal">';
- if(customSize = _getStorageItem('fv_custom_size')){
- htmlText += '<span id="fv_pin_press" class="fv_popup_pin"></span><span class="fv_popup_save"></span><span class="fv_popup_custom_text">[' + customSize.width + ' x ' + customSize.height + ']</span></li>';
- }
- else{
- htmlText += '<span id="fv_pin_press" class="fv_popup_pin"></span><span class="fv_popup_save"></span><span class="fv_popup_custom_text">自定义 N/A</span></li>';
- }
- htmlText += '<li class="fv_menu_item_normal">居中显示</li>';
- htmlText += '</ul>';
- $('#fv_popup_menu').innerHTML = htmlText;
- if(selected == 255){
- $('#fv_menu_item_custom').className = 'fv_menu_item_selected';
- }
- else{
- if(selected == 0 || POPUP_FLASH_SIZE_LIST[selected].width > _getMaxWidth() || POPUP_FLASH_SIZE_LIST[selected].height > _getMaxHeight()){
- $('#fv_popup_menu li:nth-child(1)').className = 'fv_menu_item_selected';
- }
- else{
- $('#fv_popup_menu li:nth-child(' + (selected + 1) + ')').className = 'fv_menu_item_selected';
- }
- }
- }
- function set_default_popup_option_menu_item(){
- var savedIndex = _getStorageItem('fv_saved_idx');
- do{
- $('#fv_pin_press').id = 'fv_pin_normal';
- if(savedIndex){
- switch(savedIndex)
- {
- case 255: /* custom */
- $('#fv_menu_item_custom .fv_popup_pin').id = 'fv_pin_press';
- return;
- default:
- if(POPUP_FLASH_SIZE_LIST[savedIndex].width > _getMaxWidth()
- || POPUP_FLASH_SIZE_LIST[savedIndex].height > _getMaxHeight()){
- break;
- }
- $('#fv_popup_menu li:nth-child(' + (savedIndex + 1) + ') .fv_popup_pin').id = 'fv_pin_press';
- return;
- }
- }
- }while(0);
- $('#fv_popup_menu li:nth-child(1) .fv_popup_pin').id = 'fv_pin_press';
- }
- function find_item_index(item){
- var temp = item.parentNode.firstChild;
- var i = 0;
- while( temp != item && (temp = temp.nextSibling) ){
- i++;
- }
- return i;
- }
- //fix for firefox redraw error while the embed object resized under the hidden status
- var fix_firefox_redraw_timer = null;
- function fix_firefox_redraw_error(obj){
- if(!window.opera && fix_firefox_redraw_timer == null){
- var ow = obj.width, oh = obj.height;
- resize_popup_flash(obj, ow - 1, oh - 1);
- fix_firefox_redraw_timer = setTimeout(function(){
- resize_popup_flash(obj, ow, oh);
- fix_firefox_redraw_timer = null;
- }, 10);
- }
- }
- function popup_option_click_hdlr(e){
- var item = e.target.parentNode;
- var i = find_item_index(item);
- var width = 0; height = 0;
- var flash = $('#fv_popup_player');
- var option = $('#fv_popup_option');
- var menu = $('#fv_popup_menu');
- var container = $('#fv_popup_container');
- if(flash.getElementsByTagName('embed').length != 0){
- flash = flash.getElementsByTagName('embed')[0];
- }
- if( i < (POPUP_FLASH_SIZE_LIST.length) ){ /* 预设值 */
- if( (width = POPUP_FLASH_SIZE_LIST[i].width) == 0 ){
- width = _getDefaultWidth();
- }
- if( (height = POPUP_FLASH_SIZE_LIST[i].height) == 0 ){
- height = _getDefaultHeight();
- }
- }
- else{ /* 自定义值 */
- var data = _getStorageItem('fv_custom_size');
- if(data){
- width = data.width;
- height = data.height;
- }
- }
- $('.fv_menu_item_selected').className = 'fv_menu_item_normal';
- $('#fv_popup_menu li:nth-child(' + (i+1) + ')').className = 'fv_menu_item_selected';
- _setTransition(container, 'width 0.5s ease');
- flash.style.visibility = 'hidden';
- option.style.visibility = 'hidden';
- menu.style.visibility = 'hidden';
- resize_popup_flash($('#fv_popup_player'), width, height);
- setTimeout(function(){
- set_flash_pos_no_reload();
- set_option_and_menu_pos_no_reload();
- flash.style.visibility = 'visible';
- fix_firefox_redraw_error(flash);
- option.style.visibility = 'visible';
- menu.style.visibility = 'visible';
- _setTransition(container, 'none');
- }, 500);
- }
- function popup_option_pin_click_hdlr(e){
- var li = e.target.parentNode;
- var i = find_item_index(li);
- var savedIndex = -1;
- if( i < (POPUP_FLASH_SIZE_LIST.length) ){ /* 预设值 */
- savedIndex = i;
- }
- else{
- if(_getStorageItem('fv_custom_size')){
- savedIndex = 255;
- }
- }
- if(savedIndex != -1 && _setStorageItem('fv_saved_idx', savedIndex) != false){
- set_default_popup_option_menu_item();
- }
- e.stopPropagation();
- }
- function popup_option_save_click_hdlr(e){
- var flash = $('#fv_popup_player');
- var customSize = {width: Math.round(flash.offsetWidth), height: Math.round(flash.offsetHeight)};
- if(_setStorageItem('fv_custom_size', customSize) != false){
- $('#fv_menu_item_custom .fv_popup_custom_text').textContent = '[' + customSize.width + ' x ' + customSize.height + ']';
- }
- e.stopPropagation();
- }
- function register_popup_option_menu(){
- var i = 0;
- var menu = $('#fv_popup_menu');
- if( (typeof menu) != 'undefined' ){
- var menu_item = menu.getElementsByTagName('li');
- for(i = 0; i < menu_item.length - 1; i++){
- var span = menu_item[i].getElementsByTagName('span');
- var pin = span[0], save = (span.length > 2) ? span[1] : null;
- menu_item[i].addEventListener('click', popup_option_click_hdlr, false);
- pin.addEventListener('click', popup_option_pin_click_hdlr, false);
- if(save){
- save.addEventListener('click', popup_option_save_click_hdlr, false);
- }
- }
- // “居中显示”菜单
- menu_item[i].addEventListener('click', move_popup_player_to_center, false);
- }
- }
- function init_popup_player_size(obj){
- var savedIndex = _getStorageItem('fv_saved_idx');
- var customSize = _getStorageItem('fv_custom_size');
- do{
- if(savedIndex){
- if(savedIndex == 255){ // custom
- resize_popup_flash(obj, customSize.width, customSize.height);
- return;
- }
- else if(savedIndex > 0){
- if(POPUP_FLASH_SIZE_LIST[savedIndex].width > _getMaxWidth()
- || POPUP_FLASH_SIZE_LIST[savedIndex].height > _getMaxHeight())
- {
- break;
- }
- resize_popup_flash(obj, POPUP_FLASH_SIZE_LIST[savedIndex].width, POPUP_FLASH_SIZE_LIST[savedIndex].height);
- return;
- }
- }
- }while(0);
- resize_popup_flash(obj, _getDefaultWidth(), _getDefaultHeight());
- }
- function save_original_style(obj, names){
- var i = 0;
- for(; i < names.length; i++){
- var name = names[i];
- if(!orgStyle[name]) orgStyle[name] = [];
- orgStyle[name].push(obj.style[name] || window.getComputedStyle(obj, null)[name]);
- }
- }
- function restore_original_style(obj, names){
- var i = 0;
- for(; i < names.length; i++){
- var name = names[i];
- obj.style.removeProperty(name);
- if(!orgStyle[name]) continue;
- obj.style[name] = orgStyle[name].shift();
- }
- }
- function save_size_no_reload_no_reload(obj){
- save_original_style(obj, ['width', 'height', 'top', 'left']);
- var embed = obj.getElementsByTagName('embed');
- if(embed.length >= 1){
- embed = embed[0];
- save_size_no_reload_no_reload(embed);
- }
- }
- function restore_size_no_reload_no_reload(obj){
- restore_original_style(obj, ['width', 'height', 'top', 'left']);
- var embed = obj.getElementsByTagName('embed');
- if(embed.length >= 1){
- embed = embed[0];
- restore_size_no_reload_no_reload(embed);
- }
- }
- function save_and_hide_original_player_no_reload(obj){
- save_size_no_reload_no_reload(obj);
- _saveAndSetObjAttri(obj, 'id', 'fv_popup_player');
- _saveAndSetObjAttri(obj, 'class', 'noReload');
- }
- function recover_original_player_no_reload(obj){
- if(fix_firefox_redraw_timer != null){
- clearTimeout(fix_firefox_redraw_timer);
- fix_firefox_redraw_timer = null;
- }
- _restoreObjAttr(obj, 'id');
- _restoreObjAttr(obj, 'class');
- restore_size_no_reload_no_reload(obj);
- }
- function create_popup_option_no_reload(){
- var option = _createElement('span', 'fv_popup_option', 'noReload');
- var menu = _createElement('span', 'fv_popup_menu', 'noReload');
- option.setAttribute('title', '拖拽可移动');
- document.body.appendChild(option);
- document.body.appendChild(menu);
- }
- function get_popup_player_div_pos_no_reload(){
- var div = $('#fv_popup_container');
- var divPos = _getElementXY(div);
- divPos.x -= Math.max(document.documentElement.scrollLeft, document.body.scrollLeft);
- divPos.y -= Math.max(document.documentElement.scrollTop, document.body.scrollTop);
- return {x: divPos.x, y: divPos.y};
- }
- function set_option_and_menu_pos_no_reload(){
- var option = $('#fv_popup_option');
- var menu = $('#fv_popup_menu');
- if(option && option.className == 'noReload' && menu && menu.className == 'noReload'){
- var divPos = get_popup_player_div_pos_no_reload();
- option.style.left = divPos.x - 16 + 'px';
- option.style.top = divPos.y - 16 + 'px';
- menu.style.left = divPos.x + 3 + 'px';
- menu.style.top = divPos.y + 3 + 'px';
- }
- }
- function set_flash_pos_no_reload(){
- var flash = $('#fv_popup_player');
- if(flash && flash.className == 'noReload'){
- var divPos = get_popup_player_div_pos_no_reload();;
- flash.style.top = divPos.y + 11 + 'px';
- flash.style.left = divPos.x + 11 + 'px';
- }
- }
- function create_popup_player_no_reload(obj){
- if(!$('#fv_popup_container')){
- var embed = obj.getElementsByTagName('embed');
- var div = _createElement('div', 'fv_popup_container', 'noReload');
- var divPos = null;
- init_popup_player_size(obj);
- div.style.width = parseInt(obj.width) + 'px';
- div.style.top = (window.innerHeight - parseInt(obj.height) - 11 * 2) / 2 + 'px';
- div.style.height = parseInt(obj.height) + 'px';
- div.style.visibility = 'hidden';
- $('#fv_PopupFlash').appendChild(div);
- set_flash_pos_no_reload();
- create_popup_option_no_reload();
- $('#fv_popup_option').style.visibility = 'hidden';
- set_option_and_menu_pos_no_reload();
- fill_popup_option_menu();
- set_default_popup_option_menu_item();
- register_popup_option_menu();
- div.style.visibility = 'visible';
- obj.style.visibility = 'visible';
- if(embed[0]){
- embed[0].style.visibility = 'visible';
- }
- $('#fv_popup_option').style.visibility = 'visible';
- $('#fv_popup_option').addEventListener('click', function(){
- if(!closeLock){
- $('#fv_popup_container').removeEventListener('mousemove', fv_popup_container_mousemove_hdlr, false);
- $('#fv_popup_container').removeEventListener('mousedown', fv_popup_container_mousedown_hdlr, false);
- window.removeEventListener('mouseup', mouse_up_hdlr, false);
- window.removeEventListener('mousemove', move_popup_player, false);
- this.parentNode.removeChild(this.nextSibling);
- this.parentNode.removeChild(this);
- del_black_background(obj);
- playerMoving = false;
- playerMoved = false;
- }
- }, false);
- $('#fv_popup_option').addEventListener('mousedown', function(e){
- closeLock = false;
- mouseMoveCount = 0;
- window/*this*/.addEventListener('mousemove', move_popup_player, false);
- }, false);
- fix_firefox_redraw_error(obj);
- }
- }
- function change_popup_player_edge_cursor(div, e){
- var ret = 'IS_CHANGED';
- if(e.type != 'mousemove' || !div || resizeFlag == true){
- return 'NO_CHANGE';
- }
- var x = e.pageX, y = e.pageY;
- var edge_status = check_obj_edge(div, x, y);
- var pos = _getElementXY(div);
- var size = {w: div.offsetWidth, h: div.offsetHeight};
- var o = {x: (pos.x + size.w / 2), y: (pos.y + size.h / 2)};
- switch(edge_status){
- case 'EDGE_LEFT_RIGHT':
- x > o.x ? div.style.cursor = 'e-resize' : div.style.cursor = 'w-resize';
- break;
- case 'EDGE_TOP_BOTTOM':
- y > o.y ? div.style.cursor = 's-resize' : div.style.cursor = 'n-resize';
- break;
- case 'EDGE_CORNER':
- if(x > o.x && y > o.y){
- div.style.cursor = 'se-resize';
- }
- else if(x < o.x && y < o.y){
- div.style.cursor = 'default';
- }
- else if(x < o.x && y > o.y){
- div.style.cursor = 'sw-resize';
- }
- else{
- div.style.cursor = 'ne-resize';
- }
- break;
- default:
- div.style.cursor = 'default';
- ret = 'NO_CHANGE';
- break;
- }
- return ret;
- }
- function move_popup_player(e){
- var div = document.getElementById('fv_popup_container');
- var flash = $('#fv_popup_player');
- /* 清除拖动时会框选文字的副作用 */
- if(window.getSelection() !== ''){
- window.getSelection().removeAllRanges();
- }
- /* 过滤一部分鼠标事件以提高速度 */
- if(mouseMoveCount < PLAYER_MOUSE_MOVE_FILTER){
- mouseMoveCount++;
- return;
- }
- mouseMoveCount = 0;
- playerMoving = true;
- playerMoved = true;
- closeLock = true;
- if(flash.getElementsByTagName('embed').length != 0){
- flash = flash.getElementsByTagName('embed')[0];
- }
- flash.style.visibility = 'hidden';
- $('#fv_PopupFlash').setAttribute('class', 'move');
- div.style.left = e.clientX + 'px';
- div.style.top = e.clientY + 'px';
- set_option_and_menu_pos_no_reload();
- //set_flash_pos_no_reload(); // 不需移动 flash,mouseup 时再设置位置
- }
- function move_popup_player_to_center(e){
- if(playerMoved == true){
- var div = document.getElementById('fv_popup_container');
- playerMoved = false;
- div.style.left = '0px';
- div.style.top = (window.innerHeight - div.offsetHeight) / 2 + 'px';
- $('#fv_PopupFlash').removeAttribute('class');
- set_option_and_menu_pos_no_reload();
- set_flash_pos_no_reload();
- }
- }
- function resize_popup_player(e){
- if(resizeEdge == 'EDGE_NONE' || resizeFlag == false){
- return;
- }
- var x = e.pageX, y = e.pageY;
- var multi = playerMoved ? 1 : 2;
- var adjustMode = e.shiftKey ? true : false;
- /* 清除拖动时会框选文字的副作用 */
- if(window.getSelection() !== ''){
- window.getSelection().removeAllRanges();
- }
- /* 过滤一部分鼠标事件以提高速度 */
- if(mouseMoveCount < PLAYER_MOUSE_MOVE_FILTER){
- mouseMoveCount++;
- return;
- }
- mouseMoveCount = 0;
- var div = $('#fv_popup_container'), flash = $('#fv_popup_player');
- var divPos = _getElementXY($('#fv_popup_container'));
- var divSize = {w: div.offsetWidth, h: div.offsetHeight};
- var dot = {x: (divPos.x + divSize.w / 2), y: (divPos.y + divSize.h / 2)};
- var diff = {offsetW: Math.abs(resizeMouseDwn.x - dot.x), offsetH: Math.abs(resizeMouseDwn.y - dot.y)};
- if(resizeBegin == true){
- resizeBegin = false;
- edgeLeft = (x < dot.x) ? 'EDGE_LEFT' : 'EDGE_RIGHT';
- edgeTop = (y < dot.y) ? 'EDGE_TOP' : 'EDGE_BOTTOM';
- }
- if(adjustMode){
- (edgeLeft == 'EDGE_LEFT') ? (x < adjustPreX ? ++adjustX : --adjustX) : adjustX;
- (edgeLeft == 'EDGE_RIGHT') ? (x > adjustPreX ? ++adjustX : --adjustX) : adjustX;
- (edgeTop == 'EDGE_TOP') ? (y < adjustPreY ? ++adjustY : --adjustY) : adjustY;
- (edgeTop == 'EDGE_BOTTOM') ? (y > adjustPreY ? ++adjustY : --adjustY) : adjustY;
- }
- switch(resizeEdge){
- case 'EDGE_LEFT_RIGHT':
- resize_popup_flash_by_drag(flash, flashPreSize.w + (adjustMode ? adjustX : (Math.abs(x - dot.x) - diff.offsetW) * multi), 0, edgeLeft, 'EDGE_NONE');
- break;
- case 'EDGE_TOP_BOTTOM':
- resize_popup_flash_by_drag(flash, 0, flashPreSize.h + (adjustMode ? adjustY : (Math.abs(y - dot.y) - diff.offsetH) * multi), 'EDGE_NONE', edgeTop);
- break;
- case 'EDGE_CORNER':
- if(edgeLeft == 'EDGE_LEFT' && edgeTop == 'EDGE_TOP'){
- break;
- }
- resize_popup_flash_by_drag(flash, flashPreSize.w + (adjustMode ? adjustX : (Math.abs(x - dot.x) - diff.offsetW) * multi), flashPreSize.h + (adjustMode ? adjustY : (Math.abs(y - dot.y) - diff.offsetH) * multi), edgeLeft, edgeTop);
- break;
- default:
- break;
- }
- adjustPreX = x;
- adjustPreY = y;
- }
- function fv_popup_container_mousemove_hdlr(e){
- if(change_popup_player_edge_cursor(this, e) != 'NO_CHANGE'){
- window.status = '拖拽边缘调整大小,按 Shift 拖拽可微调';
- }
- else{
- window.status = '';
- }
- }
- function fv_popup_container_mousedown_hdlr(e){
- var x = e.pageX, y = e.pageY;
- if( (resizeEdge = check_obj_edge(this, x, y)) != 'EDGE_NONE' ){
- var flash = $('#fv_popup_player');
- var embed = flash.getElementsByTagName('embed');
- var option = $('#fv_popup_option');
- resizeMouseDwn.x = x; resizeMouseDwn.y = y;
- flashFinalSize.w = 0; flashFinalSize.h = 0;
- flashPreSize = _getStyleSize(flash);
- resizeFlag = true;
- mouseMoveCount = 0;
- embed = (embed.length != 0) ? embed[0] : null;
- if(flash.style.visibility != 'hidden'){
- flash.style.visibility = 'hidden';
- }
- if(embed && embed.style.visibility != 'hidden'){
- embed.style.visibility = 'hidden';
- }
- if(option.style.visibility != 'hidden'){
- option.style.visibility = 'hidden';
- }
- adjustX = adjustY = 0;
- adjustPreX = e.pageX;
- adjustPreY = e.pageY;
- resizeBegin = true;
- edgeLeft = edgeTop = 'EDGE_NONE';
- window.addEventListener('mousemove', resize_popup_player, false);
- }
- }
- function mouse_up_hdlr(e){
- if(playerMoving == false && (resizeEdge == 'EDGE_NONE' || resizeFlag == false)){
- return;
- }
- var flash = $('#fv_popup_player');
- var embed = flash.getElementsByTagName('embed');
- var option = $('#fv_popup_option');
- _restoreTitle();
- resizeEdge = 'EDGE_NONE';
- if(resizeFlag == true){
- resizeFlag = false;
- resize_popup_flash(flash, flashFinalSize.w, flashFinalSize.h);
- }
- mouseMoveCount = 0;
- embed = (embed.length != 0) ? embed[0] : null;
- if(flash && flash.style.visibility == 'hidden'
- || (embed && embed.style.visibility == 'hidden')){
- set_flash_pos_no_reload();
- flash.style.visibility = 'visible';
- if(embed && embed.style.visibility == 'hidden'){
- embed.style.visibility = 'visible';
- }
- }
- if(option && option.style.visibility == 'hidden'){
- set_option_and_menu_pos_no_reload();
- option.style.visibility = 'visible';
- }
- fix_firefox_redraw_error(flash);
- resizeBegin = false;
- edgeLeft = edgeTop = 'EDGE_NONE';
- window.removeEventListener('mousemove', resize_popup_player, false);
- mouseMoveCount = 0;
- window/*this*/.removeEventListener('mousemove', move_popup_player, false);
- }
- function register_popup_player_drag_hdlr(){
- $('#fv_popup_container').addEventListener('mousemove', fv_popup_container_mousemove_hdlr, false);
- $('#fv_popup_container').addEventListener('mousedown', fv_popup_container_mousedown_hdlr, false);
- window.addEventListener('mouseup', mouse_up_hdlr, false);
- }
- var fv_hide_obj = null;
- function hide_original_player(obj){
- fv_hide_obj = obj.cloneNode(true);
- var x = _createElement('fv_hide_obj', 'fv_hide_obj');
- obj.parentNode.replaceChild(x, obj);
- }
- function recover_original_player(){
- var x = $('fv_hide_obj');
- if(x && fv_hide_obj){
- x.parentNode.replaceChild(fv_hide_obj, x);
- fv_hide_obj = null;
- }
- }
- function create_popup_player(htmlText){
- if(!$('#fv_popup_container')){
- var bg = $('#fv_PopupFlash');
- bg.style.backgroundImage = 'url("' + picData.loading +'")';
- bg.style.backgroundRepeat = 'no-repeat';
- bg.style.backgroundPosition = '50% 50%';
- var div = _createElement('div', 'fv_popup_container');
- var cloneObj = _createNodeByString(htmlText);
- cloneObj.id = 'fv_popup_player';
- //resize_popup_flash(cloneObj, _getDefaultWidth(), _getDefaultHeight());
- init_popup_player_size(cloneObj);
- cloneObj.setAttribute('align', 'middle');
- div.innerHTML = '\
- <span id="fv_popup_option" title="拖拽可移动"></span> \
- <span id="fv_popup_menu"></span> \
- ' + cloneObj.outerHTML + ' \
- ';
- bg.appendChild(div);
- div.style.top = (window.innerHeight - parseInt(cloneObj.height)) / 2 + 'px';
- div.style.visibility = 'hidden';
- div.style.width = _getStyleSize(cloneObj).w + 'px'; div.style.height = _getStyleSize(cloneObj).h + 'px';
- fill_popup_option_menu();
- set_default_popup_option_menu_item();
- register_popup_option_menu();
- $('#fv_popup_option').addEventListener('click', function(){
- if(!closeLock){
- this.parentNode.parentNode.removeChild(this.parentNode);
- del_black_background();
- if(randomName == 'none'){
- recover_original_player();
- }
- else{
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_RECOVER_ORIGINAL_PLAYER', confirmName: randomName};
- sendToAllFrames(JSON.stringify(fv_data));
- restore_iframe_attr_name();
- randomName = 'none';
- }
- }
- }, false);
- $('#fv_popup_option').addEventListener('mousedown', function(e){
- closeLock = false;
- mouseMoveCount = 0;
- window/*this*/.addEventListener('mousemove', move_popup_player, false);
- }, false);
- //$('#fv_popup_player').addEventListener('PluginInitialized', function(e){}, false);
- loadingTimer = setInterval(function(){
- if($('#fv_popup_player').offsetHeight > 0){
- clearInterval(loadingTimer);
- $('#fv_PopupFlash').style.backgroundImage = 'none';
- div.style.visibility = 'visible';
- //此处避免选项按钮显示不完整
- $('#fv_popup_option').style.visibility = 'hidden';
- $('#fv_popup_option').style.visibility = 'visible';
- }
- }, 200);
- }
- }
- function restore_iframe_attr_name(){
- if(window.opera){
- if(topSavedObj != null){ // in the top window
- topSavedObj.name = topSavedIframeName;
- topSavedIframeName = null;
- topSavedObj = null;
- }else if(savedIframeName != null){
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_RESTORE_IFRAME_ATTR_NAME', saved_name: savedIframeName};
- window.top.postMessage(JSON.stringify(fv_data), '*');
- savedIframeName = null;
- }
- }
- }
- function check_need_reload(obj){
- if(window == window.top
- || (window != window.top && parentWndWidth * parentWndHeight != 0 && window.innerHeight > parentWndHeight * 0.8 && window.innerWidth > parentWndWidth * 0.8)){
- return false;
- }
- else{
- return true;
- }
- }
- function convert_to_full_path_outerHTML(obj){
- var tag = _getObjTag(obj);
- if(tag != 'object' && tag != 'embed'){
- return;
- }
- obj.data && (obj.data = obj.data);
- obj.archive && (obj.archive = obj.archive);
- obj.codebase && (obj.codebase = obj.codebase);
- obj.usemap && (obj.usemap = obj.usemap);
- obj.src && (obj.src = obj.src);
- for(var i = 0; i < obj.childNodes.length; i++){
- convert_to_full_path_outerHTML(obj.childNodes[i]);
- }
- }
- function popup_icon_hdlr(obj){
- if(check_need_reload(obj) == false){
- create_black_background(obj);
- create_popup_player_no_reload(obj);
- register_popup_player_drag_hdlr();
- }
- else{
- window.fv_name = Math.random().toString();
- //避免相对路径
- convert_to_full_path_outerHTML(obj);
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_CREATE_POPUP_PLAYER', from: window.fv_name, content: obj.outerHTML};
- window.top.postMessage(JSON.stringify(fv_data), '*');
- hide_original_player(obj);
- }
- del_popup_icon();
- }
- function check_plugin_type_int(obj){
- var keyword;
- keyword = obj.getAttribute('type');
- if(keyword && keyword.toLowerCase() == 'application/x-shockwave-flash'){
- return true;
- }
- keyword = obj.getAttribute('classid');
- if(keyword && keyword.toLowerCase() == 'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000'){
- return true;
- }
- keyword = obj.getAttribute('src');
- if(keyword && keyword.toLowerCase().indexOf('.swf') != -1){
- return true;
- }
- return false;
- }
- function check_plugin_type(obj){
- var embed = null;
- var ret = false;
- if((ret = check_plugin_type_int(obj)) == false){
- embed = obj.getElementsByTagName('embed');
- if(embed.length != 0) embed = embed[0];
- ret = check_plugin_type_int(embed);
- }
- return ret;
- }
- function get_attribute_str(obj, attr){
- return obj.getAttribute(attr) ? obj.getAttribute(attr) : '';
- }
- function check_black_and_white_list(obj){
- var i = 0;
- var htmlText = get_attribute_str(obj, 'id') + get_attribute_str(obj, 'class') + get_attribute_str(obj, 'name')
- + get_attribute_str(obj, 'src') + get_attribute_str(obj, 'data') + get_attribute_str(obj, 'flashvars');
- var embed = obj.getElementsByTagName('embed');
- var param = obj.getElementsByTagName('param');
- var i = 0;
- if(embed.length != 0){
- embed = embed[0];
- htmlText += get_attribute_str(embed, 'id') + get_attribute_str(embed, 'class') + get_attribute_str(embed, 'name')
- + get_attribute_str(embed, 'src') + get_attribute_str(embed, 'data') + get_attribute_str(obj, 'flashvars');
- }
- if(param.length != 0){
- for(i = 0; i < param.length; i++){
- if(param[i].name.toLowerCase() == 'flashvars'){
- htmlText += get_attribute_str(param[i], 'value');
- }
- }
- }
- for(i = 0; i < WHITE_LIST_KEYWORD_IMPORTANT.length; i++){
- if(htmlText.toLowerCase().indexOf(WHITE_LIST_KEYWORD_IMPORTANT[i]) != -1){
- return true;
- }
- }
- for(i = 0; i < BLACK_LIST_KEYWORD.length; i++){
- if(htmlText.toLowerCase().indexOf(BLACK_LIST_KEYWORD[i]) != -1){
- return false;
- }
- }
- for(i = 0; i < WHITE_LIST_KEYWORD.length; i++){
- if(htmlText.toLowerCase().indexOf(WHITE_LIST_KEYWORD[i]) != -1){
- return true;
- }
- }
- return false;
- }
- function check_flash_size(obj){
- var width = parseInt(window.getComputedStyle(obj, null).width) || obj.width;
- var height = parseInt(window.getComputedStyle(obj, null).height) || obj.height;
- if(width < FLASH_SIZE_FILTER.width && height < FLASH_SIZE_FILTER.height){
- return false;
- }
- return true;
- }
- function show_popup_icon(obj){
- if($('#fv_popup_icon')){
- del_popup_icon();
- }
- var ele = obj;
- var objTag = _getObjTag(obj);
- var pos = null;
- if(objTag == 'embed'){
- while(ele.parentNode && _getObjTag(ele.parentNode) != 'body'){
- ele = ele.parentNode;
- if(_getObjTag(ele) == 'object') break;
- }
- if(_getObjTag(ele) != 'object'){
- ele = obj;
- }
- }
- /* 只处理 flash 插件*/
- if(check_plugin_type(ele) == false){
- return;
- }
- /* 已经打开 player 的则不再显示工具按钮*/
- if(funcKeyPress == false){
- if($('#fv_popup_container')){
- return;
- }
- if(check_black_and_white_list(ele) == false){
- return;
- }
- if(check_flash_size(ele) == false){
- return;
- }
- }
- var div = _createElement('div', 'fv_popup_icon');
- //pos = _getElementXY(ele); //如果是 object,坐标可能会有问题?
- pos = _getElementXY(obj);
- div.style.left = pos.x + 'px';
- div.style.top = pos.y + 'px';
- document.body.appendChild(div);
- div.addEventListener('click', function(e){ popup_icon_hdlr(ele); }, false);
- if(check_need_reload(ele) == true){
- div.className = 'reload';
- window.fv_name = Math.random().toString();
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_SAVE_RANDOM_NAME_2', from: window.fv_name};
- window.top.postMessage(JSON.stringify(fv_data), '*');
- }
- }
- function del_popup_icon(){
- var obj = $('#fv_popup_icon');
- if(obj){
- obj.parentNode.removeChild(obj);
- }
- else if(randomName2 != 'none'){
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_DELETE_POPUP_ICON', confirmName: randomName2};
- sendToAllFrames(JSON.stringify(fv_data));
- restore_iframe_attr_name();
- randomName2 = 'none';
- }
- }
- function popup_message_hdlr(e){
- var fv_data = null;
- try{
- fv_data = JSON.parse(e.data);
- }
- catch(e){
- return;
- }
- if(fv_data.name && fv_data.name == 'fv_popup_player'){
- if(fv_data.confirmName){
- if(!window.fv_name || fv_data.confirmName != window.fv_name){
- sendToAllFrames(e.data);
- return;
- }
- }
- else if(fv_data.confirmIframe && fv_data.confirmIframe != window.name){
- sendToAllFrames(e.data);
- return;
- }
- switch(fv_data.msg){
- /* ------ operation in parent window ------ */
- case 'MSG_ID_GET_PARENT_WINDOW_SIZE_REQ':
- sendToAllFrames(JSON.stringify({
- name: 'fv_popup_player',
- w: window.innerWidth,
- h: window.innerHeight,
- msg: 'MSG_ID_GET_PARENT_WINDOW_SIZE_RSP',
- confirmName: fv_data.verifyName
- }));
- break;
- case 'MSG_ID_CREATE_POPUP_PLAYER':
- randomName = fv_data.from;
- randomName2 = 'none'; //icon will be deleted after create popup player
- create_black_background();
- create_popup_player(fv_data.content);
- register_popup_player_drag_hdlr();
- break;
- case 'MSG_ID_SAVE_RANDOM_NAME_2':
- randomName2 = fv_data.from;
- break;
- case 'MSG_ID_RESTORE_IFRAME_ATTR_NAME':
- restore_iframe_attr_name();
- break;
- /* ------ operation in iframes ------ */
- case 'MSG_ID_GET_PARENT_WINDOW_SIZE_RSP':
- parentWndWidth = fv_data.w;
- parentWndHeight = fv_data.h;
- if(parentWndHeight != 0 && parentWndWidth != 0){
- hasFetchParentSize = true;
- }
- break;
- case 'MSG_ID_RECOVER_ORIGINAL_PLAYER':
- recover_original_player();
- break;
- case 'MSG_ID_DELETE_POPUP_ICON':
- del_popup_icon();
- break;
- case 'MSG_ID_CHECK_IF_SHOW_POPUP_ICON_FOR_IFRAME':
- savedIframeName = fv_data.saved_name;
- var bodySize = _getStyleSize(document.body);
- var obj = $$('embed') || $$('object');
- var ret = false;
- if(obj && obj.length == 1){
- obj = obj[0];
- var objSize = _getStyleSize(obj);
- if(objSize.w >= bodySize.w * 0.95 && objSize.h >= bodySize.h * 0.95){
- show_popup_icon(obj);
- ret = true;
- }
- }
- if(ret == false){
- restore_iframe_attr_name();
- }
- break;
- default:
- break;
- }
- }
- }
- window.addEventListener('resize', function(e){
- set_flash_pos_no_reload();
- set_option_and_menu_pos_no_reload();
- }, false);
- window.addEventListener('message', popup_message_hdlr, false);
- function mouseover_hdlr(e){
- var obj = e.target;
- var tag = _getObjTag(obj);
- if(tag == 'embed' || tag == 'object'){
- show_popup_icon(obj);
- }
- else if(tag == 'iframe' && window.opera){
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_CHECK_IF_SHOW_POPUP_ICON_FOR_IFRAME', saved_name: obj.name};
- topSavedIframeName = obj.name;
- topSavedObj = obj;
- obj.name = Math.random().toString();
- fv_data.confirmIframe = obj.name;
- sendToAllFrames(JSON.stringify(fv_data));
- }
- else if(obj == $('#fv_popup_icon')){
- // do nothing
- }
- else{
- del_popup_icon();
- }
- }
- window.addEventListener('mouseover', mouseover_hdlr, false);
- window.addEventListener('keydown', function(e){ funcKeyPress = (e.altKey || e.shiftKey || e.ctrlKey ) ? true : false; }, false);
- window.addEventListener('keyup', function(e){ funcKeyPress = false; }, false);
- window.addEventListener('blur', function(e){ funcKeyPress = false; }, false);
- window.addEventListener('DOMContentLoaded', function(e) { _saveTitle(); } , false);
- var hasFetchParentSize = false;
- if(document.doctype && document.doctype.name == "wml"){
- // thanks iZML
- }
- else{
- _addStyle(styleText);
- window.addEventListener('DOMNodeInserted', function(){
- if(window != window.top && !hasFetchParentSize){
- var objs = $$('object, embed');
- if(objs.length > 0){
- window.fv_name = Math.random().toString();
- var fv_data = {name: 'fv_popup_player', msg: 'MSG_ID_GET_PARENT_WINDOW_SIZE_REQ', verifyName: window.fv_name};
- window.top.postMessage(JSON.stringify(fv_data), '*');
- }
- }
- }, false);
- }
- })(window.opera ? window.opera.scriptStorage : undefined);