基于jquery创建的一个图片、视频缓冲的效果样式插件

代码如下:

(function($) {
$.fn.scrollWait = function(options) {
var ops = $.extend({}, $.fn.scrollWait.defaults, options);
var opts = $.meta ? $.extend({}, ops, $(this).data()) : ops;
/**
* 显示位置
*/
var win = $(window);
var winheight = win.height();
var winwidth = win.width();
var dsize = opts.size;
var top = opts.top;
var left = opts.left;
var dtop = !top && top != "" && typeof top != "undefined" && top != 0
? (winheight - dsize) / 2
: top;
var dleft = !left && left != "" && typeof left != "undefined"
&& left != 0 ? (winwidth - dsize) / 2 : left;
// 原点数量
var num = opts.num;
// 原点直径
var R = dsize / num * opts.areaWeight;
// 半径
var r = 1 / 2 * R;
// 外侧圆直径
var outerR = 1 / 2 * dsize;
// 内侧圆直径
var innerR = outerR - R;
// 遍历添加原点对象
for (var i = 0; i < num; i++) {
$('body').append($("<div class=\"innerCircle\" id=\"innerCircle"
+ i + "\"></div>"));
}
// 其实坐标0,0
var i = 0;
var innerArray = new Array(num);
/**
* 计算内圆上个点的中心坐标
*/
for (var j = 0; j < innerArray.length; j++) {
var x, y;
var ang = i * 360 / num;
if (0 <= ang && ang <= 90) {
x = outerR * Math.sin(ang / 180 * Math.PI) + outerR;
y = outerR - outerR * Math.cos(ang / 180 * Math.PI);
}
if (90 < ang && ang <= 180) {
x = outerR * Math.cos((ang - 90) / 180 * Math.PI) + outerR;
y = outerR * Math.sin((ang - 90) / 180 * Math.PI) + outerR;
}
if (180 < ang && ang <= 270) {
x = outerR - outerR * Math.sin((ang - 180) / 180 * Math.PI);
y = outerR * Math.cos((ang - 180) / 180 * Math.PI) + outerR;
}
if (270 < ang && ang <= 360) {
x = outerR - outerR * Math.cos((ang - 270) / 180 * Math.PI);
y = outerR - outerR * Math.sin((ang - 270) / 180 * Math.PI);
}
innerArray[j] = new Array(dtop + y - r, dleft + x - r);
i++;
}
/**
* 画圆
*/
$(".innerCircle").each(function() {
$(this).css({
'width' : R + "px",
'height' : R + "px",
'border-top-left-radius' : r + "px",
'border-top-right-radius' : r + "px",
'border-bottom-left-radius' : r + "px",
'border-bottom-right-radius' : r + "px"
});
});
for (var i = 0; i < num; i++) {
$("#innerCircle" + i).css({
'top' : innerArray[i][0] + "px",
'left' : innerArray[i][1] + "px"
});
}
// 查找当前暂停的圆的位置
var val = $("#current").val();
if (val == undefined || val == "") {
$("body").append($("<input type=\"hidden\" id=\"current\">"));
k = 0;
} else {
k = val;
}
var o = new Object();
var timer;
// 开始旋转
o.start = function() {
var first;
var g = $("#grade").val();
if (g == undefined || g == "") {
$("body").append($("<input type=\"hidden\" id=\"grade\">"));
first = 1;
} else {
first = g;
}
timer = setInterval(function() {
if (first % 2 == 1) {
$("#innerCircle" + k).removeClass("innerCircle")
.addClass("innerCircle-change");
}
if (first % 2 == 0) {
$("#innerCircle" + k).removeClass("innerCircle-change")
.addClass("innerCircle");
}
if (k == (num - 1)) {
k = 0;
console.log(first);
first++;
$("#grade").val(first);
} else {
k++;
}
// 覆盖值
$("#current").val(k);
}, opts.speed);
return this;
}
// 暂停
o.stop = function() {
clearInterval(timer);
return this;
}
// 结束
o.end = function() {
clearInterval(timer);
// 移除所有元素
$(".innerCircle,.innerCircle-change,#current,#grade").remove();
}
return o;
}
$.fn.scrollWait.defaults = {
size : 80,
top : null,
left : null,
// 数量
num : 8,
speed : 200,
// 圆点占整个面积的比重
areaWeight : 5 / 4
};
})(jQuery);

调用方法:


代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>MyHtml.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" type="text/css"
href="scroll-wait-jquery-plugin.css">
</head>
<script type="text/javascript" src="jquery-1.7.js"></script>
<script type="text/javascript" src="scroll-wait-jquery-plugin.js"></script>
<script type="text/javascript">
$(document).ready(function(){
var w=$("body").scrollWait();
w.start();
setTimeout(function() {w.stop();},1000);
setTimeout(function() {w.start();},2000);
setTimeout(function() {w.stop();},3000);
setTimeout(function() {w.start();},4000);
setTimeout(function() {w.stop();},5000);
setTimeout(function() {w.start();},6000);
setTimeout(function() {w.end();},7000);
});
</script>
<body>
</body>
</html>

css:


代码如下:

.innerCircle {
position: absolute;
background: #FFFF00;
opacity: 0.8;
}
.innerCircle-change {
background: #333;
position: absolute;
}

(0)

相关推荐

  • 精通Javascript+jQuery 视频教程 在线观看

    JavaScript/CSS/DOM基础 第0课 - 内容概述 第1课 - JavaScript背景知识 第2课 - JavaScript基础 第3课 - CSS基础 第4课 - CSS进阶 第5课 - DOM模型 JavaScript开发进阶 第6课 - JavaScript事件 第7课 - 表格与表单 第8课 - Javascript调试与优化 第9课 - Ajax jQuery应用 第10课 - jQuery基础 第11课 - jQuery控制页面 第12课 - jQuery动画特效 第1

  • 12款经典的白富美型—jquery图片轮播插件—前端开发必备

    图片轮播是网站中的常用功能,用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美的图片轮播效果,希望这些插件能够帮助到你. Nivo Slider 首先推荐的这款插件号称世界上最棒的图片轮播插件,有独立的 jQuery 插件和 WordPress 插件两个版本. 目前下载量已经突破 1,800,000 次!jQuery 独立版本的插件主要有如下特色: ✓  16个独特的过渡效果

  • jquery点击缩略图切换视频播放特效代码分享

    本文实例讲述了jquery点击缩略图切换视频播放特效.分享给大家供大家参考.具体如下: jquery点击缩略图切换视频播放是一款非常实用的播放代码,点击视频缩略图切换优酷视频播放的视频播放选项卡代码,支持flash视频切换选项卡. 运行效果图:      -------------------查看效果 下载源码------------------- 小提示:浏览器中如果不能正常运行,可以尝试切换浏览模式. 为大家分享的jquery点击缩略图切换视频播放特效代码如下 <!DOCTYPE html

  • Jquery插件 easyUI属性汇总

    此属性列表请对照jQuery EasyUI 1.0.5,关于它的更多资讯请猛击这里. 属性分为CSS片段和JS片段. CSS类定义:1.div easyui-window        生成一个window窗口样式.      属性如下:                   1)modal:是否生成模态窗口.true[是] false[否]                   2)shadow:是否显示窗口阴影.true[显示] false[不显示] 2.div easyui-panel    

  • 强烈推荐240多个jQuery插件提供下载

    jQuery 是一个快速的,简洁的 javaScript 库,使用户能更方便地处理 HTML documents.events.实现动画效果,并且方便地为网站提供 AJAX 交互. jQuery 还有一个比较大的优势是,它的文档说明很全,而且各种应用也说得很详细,同时还有许多成熟的插件可供选择. jQuery 能够使用户的 html 页保持代码和 html 内容分离,也就是说,不用再在 html 里面插入一堆js来调用命令了,只需定义 id 即可.今天在Kollermedia.at上发现了一篇J

  • jQuery实现视频作为全屏幕背景

    先上效果图 完整代码如下 复制代码 代码如下: <!doctype html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <title>如何使用jQuery制作全屏幕背景的嵌入mp4-柯乐义</title>

  • Jquery实现视频播放页面的关灯开灯效果

    本示例使用Jquery实现视频播放页面的关灯开灯效果.其中视频显示使用embed 元素,该元素是html5的元素,所以使用支持html5的浏览器效果会更好. 效果预览网址:http://www.keleyi.com/keleyi/phtml/guandeng/ 完整代码: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtm

  • jQuery插件JWPlayer视频播放器用法实例分析

    本文实例讲述了jQuery插件JWPlayer视频播放器用法.分享给大家供大家参考,具体如下: JWPlayer 插件播放视频播放器 使用方法: <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@ page contentType="text/html; charset=UTF-8"%> <!DOCTYPE html> <

  • jQuery实现仿腾讯视频列表分页效果的方法

    本文实例讲述了jQuery实现仿腾讯视频列表分页效果的方法.分享给大家供大家参考.具体如下: 这里使用jQuery仿腾讯视频列表分页效果,无刷新分页特效,点击分页按钮,无刷新进入下一页内容列表. 运行效果截图如下: 具体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&q

  • 推荐10个2014年最佳的jQuery视频插件

    在这篇文章中已经收集了10个最佳的jQuery视频插件,帮助开发人员容易地实现网站播放影片功能.可以显示视频和视频播放列表. 1. Bigvideo.js BigVideo.js 是一个jQuery插件能够,让你很方便将视频作为网站的背景. 它可以默默地播放一个视频,或用一个列表让用户选择他们喜欢的进行播放. 这个插件基于Video.js构建.此外如果有些设备不支持自动播放支持显示成图片. 2. jPlayer jPlayer是一个可定制和更换皮肤的开源JQuery的播放器,允许在网页中播放音频

  • jquery html5 视频播放控制代码

    jQuery HTML5 视频播放控制核心代码: <video class="pause" controls poster="images/vedio.jpg" width="663" height="373"> <source src="video/Defone3.8_1.mp4" type="video/mp4"> 您的浏览器不支持html5! </vi

  • 分享一款基于jQuery的视频播放插件

    最近写了一个在线视频播放的功能,感觉这个插件还可以,和大家分享一下! 复制代码 代码如下: <div class="report" id="play-product" style="cursor: pointer"  data-flv="视频路径地址"></div> <script type="text/javascript"> //播放视频 $('#play-produ

随机推荐