JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果
JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果
今天是2014年第一篇博客是关于类似于我们的qq空间长图片展示效果,因为一张很长的图片不可能全部把他展示出来,所以外层用了一个容器给他一个高度,超过高度后隐藏掉。当我停留在长图片下部时候 他会自动向上滚动效果,同理 鼠标移到图片上部时候 会自动向下滚动。特地研究下。我们先来看看QQ空间的效果吧!如下图所示:
基本原理
实现他的原理很简单:就是页面一进来时候 在长图片下动态生成2个div 第一个绝对定位在图片的上部位置,第二个绝对定位在外层容器的高度1/2的地方,那么当我鼠标移到第二张图片时候 向上滚动 否则的话 移到第一张图片时候 向下滚动。为了更好的说明问题 我们可以先看看如下原理图:
其中:中间有个简单的时间算法问题:
1. 向上移动效果计算下时间。
先判断当前的图片有没有向上滚动(通过top来判断 默认情况下为0),如果已经向上滚动的话
var time = (图片的总高度 - 已经滚动的top)/ 配置项的speed
注意:speed传进来的参数越大 那么滚动的越慢 默认为150.
否则的话 如果没有滚动的话 那么
var time = 图片的总高度 / 配置项的speed
那么接下来的动画animate 就是 ({top:-$imgHeight + $(tagParent).height()},$time * 1000,"linear");
记住:当前图片的高度一定要减去 - 父容器的高度 也就是说 在一定的时间内 滚动这么长的距离 减去父容器的高度目的是为了当滚动最后一个的高度的时候 就停止滚动 否则的话 他会一直滚动到最后 会留一个空白的页面(这不是我们想要的效果).
2. 向下移动效果计算下时间。
直接获取已经滚动的top 然后time的计算如下:
var time = 已经滚动的top/配置项的speed;
然后动画animate animate({top:0},$time * 1000,"linear");
在规定的时间内 滚动到top为0的位置上。
jsfiddle 效果链接如下:
http://jsfiddle.net/longen/mf9Gk/9/embedded/result/ 可以复制 运行下
代码如下:
HTML
<div class="outDiv">
<div class="innerDiv" data-img = 'true'>
<img src="test.jpg" class="targetImg"/>
</div>
</div>
css
<style type="text/css">
*{padding:0px;margin:0px;list-style-type:none;}
.outDiv{border:1px solid #ddd;width:500px;height:500px;padding:20px;margin:20px auto;background:#7ce;}
.innerDiv{width:500px;height:500px;position:relative;background:#fff;overflow:hidden;}
</style>
JS
/**
* JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果
* @date 2014-1-1
* @author tugenhua
* @email 879083421@qq.com
*/ function LongPicShow(options) { this.config = {
targetImg : '.targetImg', // 当前图片的元素
speed : 150 // 默认为150 值越小 执行的越慢 time = 图片height/speed
}; this.cache = { };
this.init(options);
} LongPicShow.prototype = { init: function(options) {
var self = this,
_config = self.config,
_cache = self.cache; // 插入div
self._insertDiv(); // 设置css样式
self._setCss(); // 鼠标移上去的事件
self._hover();
},
// 页面初始化 插入div
_insertDiv: function(){
var self = this,
_config = self.config; $(_config.targetImg).each(function(index,item){
var tagParent = $(item).parent();
$(tagParent).append('<div class="topDiv"></div><div class="bottomDiv"></div>');
});
},
// 设定css样式
_setCss: function(){
var self = this,
_config = self.config,
_cache = self.cache;
$(_config.targetImg).each(function(index,item){
var tagParent = $(item).parent(),
parentWidth = $(tagParent).width(),
parentHeight = $(tagParent).height();
$(tagParent).css({
'position':'relative'
});
$('.topDiv',tagParent).css({
'height':parentHeight/2 + 'px',
'width':parentWidth + 'px',
'cursor':'pointer',
'background':'#fff',
'position':'absolute',
'filter':'alpha(opacity=0)',
'top': 0,
'opacity':0
});
$('.bottomDiv',tagParent).css({
'height':parentHeight/2 + 'px',
'width':parentWidth + 'px',
'cursor':'pointer',
'background':'#fff',
'position':'absolute',
'filter':'alpha(opacity=0)',
'opacity':0,
'top':parentHeight/2 + 'px'
}); });
},
/*
* 鼠标移上触发的事件
*/
_hover: function(){
var self = this,
_config = self.config,
_cache = self.cache; $(_config.targetImg).each(function(index,item){ var tagParent = $(item).parent();
// 向上移动 鼠标移到第二个div上
$($(tagParent).find('div')[1]).hover(function(){ var $imgHeight = $(item).height(),
topStr= $(item).css("top").split("px")[0],
$top,
$time;
if(topStr.split("-")[1]) {
$top = parseFloat(topStr.split("-")[1]);
$time = ($imgHeight-$top)/_config.speed;
}else {
$time = $imgHeight/_config.speed;
}
$(item).css('position','absolute');
$(item).animate({top:-$imgHeight + $(tagParent).height()},$time * 1000,"linear");
},function(){
$(item).stop();
}); // 向下移动 鼠标移到第一个div上
$($(tagParent).find('div')[0]).hover(function(){ var $imgHeight = $(item).height(),
topStr= $(item).css("top").split("px")[0],
$top,
$time; $top = parseFloat(topStr.split("-")[1]);
$time = $top/_config.speed;
$(item).css('position','absolute');
$(item).animate({top:0},$time * 1000,"linear");
},function(){
$(item).stop();
});
});
}
};
JS仿QQ空间鼠标停在长图片时候图片自动上下滚动效果的更多相关文章
- Html - 仿QQ空间右下角工具浮动块
仿QQ空间右下角工具浮动块 <style type="text/css"> .cy-tp-area>.cy-tp-fixbtn>.cy-tp-text { ...
- 仿QQ空间和微信朋友圈,高解耦高复用高灵活
先看看效果: 用极少的代码实现了 动态详情 及 二级评论 的 数据获取与处理 和 UI显示与交互,并且高解耦.高复用.高灵活. 动态列表界面MomentListFragment支持 下拉刷新与上拉加载 ...
- 仿QQ空间动态界面分享
先看看效果: 用极少的代码实现了 动态详情 及 二级评论 的 数据获取与处理 和 UI显示与交互,并且高解耦.高复用.高灵活. 动态列表界面MomentListFragment支持 下拉刷新与上拉加载 ...
- Fragment,仿QQ空间
转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9023451 在今天的这篇文章当中,我依然会以实战加理论结合 ...
- iOS传感器集锦、飞机大战、开发调试工具、强制更新、Swift仿QQ空间头部等源码
iOS精选源码 飞机大作战 MUPhotoPreview -简单易用的图片浏览器 LLDebugTool是一款针对开发者和测试者的调试工具,它可以帮... 多个UIScrollView.UITable ...
- 仿QQ空间长图效果简易版--母亲节感恩
手机网站 母亲节最火的两件事 1.NBA 杜兰特在获MVP催泪致辞献给母亲:她才是真的MVP. 2.QQ空间长图 ------------------------------------------- ...
- js仿QQ拖拽删除
原生js实现仿QQ拖拽删除交互,无需任何依赖. 项目演示请看这里, gitHub请移步这里. 由于源码很长,所以贴到最下面了. 效果截图如下: 核心思想呢,就是点击圆点的时候全屏覆盖个canvas,在 ...
- mui开发app之多图压缩与上传(仿qq空间说说发表)
欲实现效果图 提出需求点: 用户可自由添加删除替换多张图片,并且显示相应缩略图,限制为8张 用户可选择压缩图或直接上传原图功能 返回提醒用户会丢失填写的信息 下面一个个实现上述需求,从简单到复杂: 需 ...
- 仿QQ空间根据位置弹出PopupWindow显示更多操作效果
我们打开QQ空间的时候有个箭头按钮点击之后弹出PopupWindow会根据位置的变化显示在箭头的上方还是下方,比普通的PopupWindow弹在屏幕中间显示好看的多. 先看QQ空间效果图: ...
随机推荐
- hadoop的namenode启动失败
1.jps发现namenode启动失败 每次开机都要重新格式化一下namenode才可以 其实问题出现自tmp文件上,因为每次开机就会被清空,所以现在我们配置一个tmp文件目录. 如果之前没有配置过, ...
- HDU3359(SummerTrainingDay05-I 高斯消元)
Kind of a Blur Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- 水平方向margin:auto
先上图 由图可看到,块级元素的水平方向上又"7大属性":margin-left.border-left.padding-left.margin-left.width.paddi ...
- js常用正则收集
1:非纯空白字符串且长度大于1: /^\s*\S+[\s\S]*$/ 右侧可以正常匹配:“ 11 1 1 a ” .“ 1 aa” . ...
- 怎样删除PeopleSoft进程服务器定义
比如在克隆环境时候,把生产的环境克隆到DEV环境,你可能会在进程调度服务器中看到了生产的进程服务器,例如:你可能会在进程调度的时候选择一个server,但是这个server并没有在psadmin下创建 ...
- Play framework 安装
1.确定配置好了Java环境,在命令窗口输入java -version,得到版本号,则表示配好了Java环境 2.下载play文件进行安装http://www.playframework.org/,下 ...
- the database needs something to populate existing rows.
这是我在使用Django进行models编写时的一个错误. 解决办法: 为其指定一个默认值即可 object_id = models.CharField(max_length=50, default= ...
- 从零自学Java-5.使用条件测试进行判断
1.使用if语句进行最基本的条件测试:2.测试一个值大于还是小于另一个值:3.测试两个值是否相等:4.使用与if语句对应的else语句:5.组合多个条件测试:6.使用switch语句进行复杂的条件测试 ...
- jquery中ajax的dataType的各种属性含义
参考ajax api文档:http://www.w3school.com.cn/jquery/ajax_ajax.asp dateType后接受的参数参数类型:string 预期服务器返回的数据类型. ...
- Oracle EBS INV 创建物料搬运单头
CREATE OR REPLACE PROCEDURE XX_CreateMoveOrderHeader AS -- Common Declarations l_api_version NUMBER ...