点击预览按钮,弹出窗口自动播放视频文件,并伴有遮罩层
从网上自行下载jquery-1.11.2.min.js(版本自己选择)和flvplayer.swf文件。需要注意的是网上一般有两个版本的flvplayer.swf。
1、第一种flvplayer.swf(将下面的代码嵌套到demo.html中)
<p id="player1">
<script type="text/javascript">
var s1 = new SWFObject("flvplayer.swf","single","1000","600","10");
s1.addParam("allowfullscreen","true");
//文件引用为file
s1.addVariable("file","test1.mp4");
//是否自动播放,true:是,false:否
s1.addVariable("autostart","true");
//是否循环播放,true:是,false:否
s1.addVariable("repeat","true");
s1.addVariable("image","preview.png")
s1.addParam("width","1000");
s1.addParam("height","600");
s1.write("player1");
script>
P>
生成的代码为:
<embed type="application/x-shockwave-flash" src="flvplayer.swf" width="1000" height="600" style="undefined" id="single" name="single" quality="high" allowfullscreen="true" flashvars="file=test1.mp4&autostart=true&repeat=true&image=preview.png">embed>
效果:
2、第二种flvplayer.swf(将下面的代码嵌套到demo.html中)
<p id="player1">
<script type="text/javascript">
var s1 = new SWFObject("flvplayer.swf","single","1000","600","10");
s1.addParam("allowfullscreen","true");
//文件引用为vcastr_file
s1.addVariable("vcastr_file","test1.mp4");
s1.addVariable("image","preview.png")
//是否自动播放,1:是,0:否
s1.addVariable("IsAutoPlay","1");
//是否循环播放,1:是,0:否
s1.addVariable("IsContinue","1");
s1.addParam("width","1000");
s1.addParam("height","600");
s1.write("player1");
script>
P>
生成的代码为:
<embed type="application/x-shockwave-flash" src="flvplayer.swf" width="1000" height="600" style="undefined" id="single" name="single" quality="high" allowfullscreen="true" flashvars="vcastr_file=test1.mp4&IsAutoPlay=1&IsContinue=1&image=preview.png">embed>
效果:
需要根据自己所下载的flvplayer.swf判断使用哪种,并注意区别。
demo.html
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="古成"/>
<title>弹出全屏遮罩层播放视频title>
<script type="text/javascript" src="js/swfobject.js">script>
head>
<body>
<a class="btnDel" href="#" style="font: '微软雅黑';font-size: 14px;width: 125px;height: 33px;cursor: pointer;">观看电影a>
<div class="box-mask" style="position: fixed; top: 0; left: 0; width: 100%; height: 100%;background: #000; opacity: 0.5; filter: alpha(opacity=50);z-index: 99;display: none;">div>
<div class="box" style="position: absolute; width: 1000px; height: 620px; line-height:620px; text-align: center; z-index: 101;display: none;">
<input class="btnCancel" style="float:right;" type="button" value="关闭">
<div class="demo" style="width:100%; height:100%;margin:0 auto;">
<p id="player1">
//根据所下flvplayer.swf,参考上面说的修改
<script type="text/javascript">
var s1 = new SWFObject("flvplayer.swf","single","1000","600","10");
s1.addParam("allowfullscreen","true");
s1.addVariable("file","test1.mp4");
s1.addVariable("autostart","true");
s1.addVariable("repeat","true");
s1.addParam("width","1000");
s1.addParam("height","600");
s1.write("player1");
script>
p>
div>
div>
<script src="js/jquery-1.11.2.min.js">script>
<script type="text/javascript" src="js/test.js">script>
body>
html>
test.js
/**
* Created by Administrator on 2017/9/30.
*/
$(document).ready(function() {
var isOpen = 0;
//全局变量,判断是否已经打开弹出框
$(".btnDel").click(function() {
//$(".box-mask").css({"display":"block"});
$(".box-mask").fadeIn(500);
center($(".box"));
//载入弹出窗口上的按钮事件
checkEvent($(this).parent(), $(".btnSure"), $(".btnCancel"));
setTimeout(function () {
$("#single").trigger("click");
},1000);
});
function center(obj) {
//obj这个参数是弹出框的整个对象
var screenWidth = $(window).width(), screenHeigth = $(window).height();
//获取屏幕宽高
var scollTop = $(document).scrollTop();
//当前窗口距离页面顶部的距离
var objLeft = (screenWidth - obj.width()) / 2;
///弹出框距离左侧距离
var objTop = (screenHeigth - obj.height()) / 2 + scollTop;
///弹出框距离顶部的距离
obj.css({
left:objLeft + "px",
top:objTop + "px"
});
obj.fadeIn(500);
//弹出框淡入
isOpen = 1;
//弹出框打开后这个变量置1 说明弹出框是打开装填
//当窗口大小发生改变时
$(window).resize(function() {
//只有isOpen状态下才执行
if (isOpen == 1) {
//重新获取数据
screenWidth = $(window).width();
screenHeigth = $(window).height();
var scollTop = $(document).scrollTop();
objLeft = (screenWidth - obj.width()) / 2;
var objTop = (screenHeigth - obj.height()) / 2 + scollTop;
obj.css({
left:objLeft + "px",
top:objTop + "px"
});
obj.fadeIn(500);
}
});
//当滚动条发生改变的时候
$(window).scroll(function() {
if (isOpen == 1) {
//重新获取数据
screenWidth = $(window).width();
screenHeigth = $(window).height();
var scollTop = $(document).scrollTop();
objLeft = (screenWidth - obj.width()) / 2;
var objTop = (screenHeigth - obj.height()) / 2 + scollTop;
obj.css({
left:objLeft + "px",
top:objTop + "px"
});
obj.fadeIn(500);
}
});
}
//导入两个按钮事件 obj整个页面的内容对象,obj1为确认按钮,obj2为取消按钮
function checkEvent(obj, obj1, obj2) {
//确认后删除页面所有东西
obj1.click(function() {
//移除所有父标签内容
obj.remove();
//调用closed关闭弹出框
closed($(".box-mask"), $(".box"));
});
//取消按钮事件
obj2.click(function() {
//调用closed关闭弹出框
closed($(".box-mask"), $(".box"));
});
}
//关闭弹出窗口事件
function closed(obj1, obj2) {
obj1.fadeOut(500);
obj2.fadeOut(500);
isOpen = 0;
}
});
swfobject.js
if(typeof deconcept=="undefined"){var deconcept=new Object();}if(typeof deconcept.util=="undefined"){deconcept.util=new Object();}if(typeof deconcept.SWFObjectUtil=="undefined"){deconcept.SWFObjectUtil=new Object();}deconcept.SWFObject=function(_1,id,w,h,_5,c,_7,_8,_9,_a){if(!document.getElementById){return;}this.DETECT_KEY=_a?_a:"detectflash";this.skipDetect=deconcept.util.getRequestParameter(this.DETECT_KEY);this.params=new Object();this.variables=new Object();this.attributes=new Array();if(_1){this.setAttribute("swf",_1);}if(id){this.setAttribute("id",id);}if(w){this.setAttribute("width",w);}if(h){this.setAttribute("height",h);}if(_5){this.setAttribute("version",new deconcept.PlayerVersion(_5.toString().split(".")));}this.installedVer=deconcept.SWFObjectUtil.getPlayerVersion();if(!window.opera&&document.all&&this.installedVer.major>7){deconcept.SWFObject.doPrepUnload=true;}if(c){this.addParam("bgcolor",c);}var q=_7?_7:"high";this.addParam("quality",q);this.setAttribute("useExpressInstall",false);this.setAttribute("doExpressInstall",false);var _c=(_8)?_8:window.location;this.setAttribute("xiRedirectUrl",_c);this.setAttribute("redirectUrl","");if(_9){this.setAttribute("redirectUrl",_9);}};deconcept.SWFObject.prototype={useExpressInstall:function(_d){this.xiSWFPath=!_d?"expressinstall.swf":_d;this.setAttribute("useExpressInstall",true);},setAttribute:function(_e,_f){this.attributes[_e]=_f;},getAttribute:function(_10){return this.attributes[_10];},addParam:function(_11,_12){this.params[_11]=_12;},getParams:function(){return this.params;},addVariable:function(_13,_14){this.variables[_13]=_14;},getVariable:function(_15){return this.variables[_15];},getVariables:function(){return this.variables;},getVariablePairs:function(){var _16=new Array();var key;var _18=this.getVariables();for(key in _18){_16[_16.length]=key+"="+_18[key];}return _16;},getSWFHTML:function(){var _19="";if(navigator.plugins&&navigator.mimeTypes&&navigator.mimeTypes.length){if(this.getAttribute("doExpressInstall")){this.addVariable("MMplayerType","PlugIn");this.setAttribute("swf",this.xiSWFPath);}_19=" false;}if(this.major>fv.major){return true;}if(this.minorreturn false;}if(this.minor>fv.minor){return true;}if(this.revreturn false;}return true;};deconcept.util={getRequestParameter:function(_2b){var q=document.location.search||document.location.hash;if(_2b==null){return q;}if(q){var _2d=q.substring(1).split("&");for(var i=0;i<_2d.length;i++){if(_2d[i].substring(0,_2d[i].indexOf("="))==_2b){return _2d[i].substring((_2d[i].indexOf("=")+1));}}}return "";}};deconcept.SWFObjectUtil.cleanupSWFs=function(){var _2f=document.getElementsByTagName("OBJECT");for(var i=_2f.length-1;i>=0;i--){_2f[i].style.display="none";for(var x in _2f[i]){if(typeof _2f[i][x]=="function"){_2f[i][x]=function(){};}}}};if(deconcept.SWFObject.doPrepUnload){if(!deconcept.unloadSet){deconcept.SWFObjectUtil.prepUnload=function(){__flash_unloadHandler=function(){};__flash_savedUnloadHandler=function(){};window.attachEvent("onunload",deconcept.SWFObjectUtil.cleanupSWFs);};window.attachEvent("onbeforeunload",deconcept.SWFObjectUtil.prepUnload);deconcept.unloadSet=true;}}if(!document.getElementById&&document.all){document.getElementById=function(id){return document.all[id];};}var getQueryParamValue=deconcept.util.getRequestParameter;var FlashObject=deconcept.SWFObject;var SWFObject=deconcept.SWFObject;