图片横向循环滚动,总是滚一会会跳下怎么办

hi_hamster 2017-08-04 04:45:15
本菜鸟还不会改js代码,好头疼
这是我根据布局写的css
.marquee{width:740px;height:108px;margin:10px 15px 15px 0;float: right;overflow:hidden;}
.marquee ul{width:740px;height: 108px;}
.marquee ul li{width:152px;height:108px;border:1px solid #CCC;float:left;margin-right:8px;}
.marquee img{width:150px;height:106px;padding:1px;}

这是我模的js,这里我搞不清楚

<scriptt>
(function($){

$.fn.kxbdMarquee = function(options){
var opts = $.extend({},$.fn.kxbdMarquee.defaults, options);

return this.each(function(){
var $marquee = $(this);//滚动元素容器
var _scrollObj = $marquee.get(0);//滚动元素容器DOM
var scrollW = $marquee.width();//滚动元素容器的宽度
var scrollH = $marquee.height();//滚动元素容器的高度
var $element = $marquee.children(); //滚动元素
var $kids = $element.children();//滚动子元素
var scrollSize=0;//滚动元素尺寸
var _type = (opts.direction == 'left' || opts.direction == 'right') ? 1:0;//滚动类型,1左右,0上下

//防止滚动子元素比滚动元素宽而取不到实际滚动子元素宽度
$element.css(_type?'width':'height',10000);
//获取滚动元素的尺寸
if (opts.isEqual) {
scrollSize = $kids[_type?'outerWidth':'outerHeight']() * $kids.length;
}else{
$kids.each(function(){
scrollSize += $(this)[_type?'outerWidth':'outerHeight']();
});
}
//滚动元素总尺寸小于容器尺寸,不滚动
if (scrollSize<(_type?scrollW:scrollH)) return;
//克隆滚动子元素将其插入到滚动元素后,并设定滚动元素宽度
$element.append($kids.clone()).css(_type?'width':'height',scrollSize*2);

var numMoved = 0;
function scrollFunc(){
var _dir = (opts.direction == 'left' || opts.direction == 'right') ? 'scrollLeft':'scrollTop';
if (opts.loop > 0) {
numMoved+=opts.scrollAmount;
if(numMoved>scrollSize*opts.loop){
_scrollObj[_dir] = 0;
return clearInterval(moveId);
}
}
if(opts.direction == 'left' || opts.direction == 'up'){
var newPos = _scrollObj[_dir] + opts.scrollAmount;
if(newPos>=scrollSize){
newPos -= scrollSize;
}
_scrollObj[_dir] = newPos;
}else{
var newPos = _scrollObj[_dir] - opts.scrollAmount;
if(newPos<=0){
newPos += scrollSize;
}
_scrollObj[_dir] = newPos;
}
};
//滚动开始
var moveId = setInterval(scrollFunc, opts.scrollDelay);
//鼠标划过停止滚动
$marquee.hover(
function(){
clearInterval(moveId);
},
function(){
clearInterval(moveId);
moveId = setInterval(scrollFunc, opts.scrollDelay);
}
);

//控制加速运动
if(opts.controlBtn){
$.each(opts.controlBtn, function(i,val){
$(val).bind(opts.eventA,function(){
opts.direction = i;
opts.oldAmount = opts.scrollAmount;
opts.scrollAmount = opts.newAmount;
}).bind(opts.eventB,function(){
opts.scrollAmount = opts.oldAmount;
});
});
}
});
};
$.fn.kxbdMarquee.defaults = {
isEqual:true,//所有滚动的元素长宽是否相等,true,false
loop: 0,//循环滚动次数,0时无限
direction: 'left',//滚动方向,'left','right','up','down'
scrollAmount:1,//步长
scrollDelay:1,//时长
newAmount:1,//加速滚动的步长
eventA:'mousedown',//鼠标事件,加速
eventB:'mouseup'//鼠标事件,原速
};

$.fn.kxbdMarquee.setDefaults = function(settings) {
$.extend( $.fn.kxbdMarquee.defaults, settings );
};

})(jQuery);
</script>
...全文
262 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
y3832702 2017-08-07
  • 打赏
  • 举报
回复
或者scrollSize = ($kids[_type?'outerWidth':'outerHeight'](true) ) * $kids.length;
y3832702 2017-08-07
  • 打赏
  • 举报
回复
//获取滚动元素的尺寸 if (opts.isEqual) { scrollSize = $kids[_type?'outerWidth':'outerHeight']() * $kids.length; }else{ $kids.each(function(){ scrollSize += $(this)[_type?'outerWidth':'outerHeight'](); }); } 这里加上margin-right的距离 scrollSize = ($kids[_type?'outerWidth':'outerHeight']() + parseInt($kids.css('marginRight'))) * $kids.length;
hi_hamster 2017-08-07
  • 打赏
  • 举报
回复
内容概要:本文系统研究了线性模型预测控制(LMPC)与非线性模型预测控制(NMPC)在四旋翼无人机轨迹跟踪任务中的控制性能对比,基于Matlab/Simulink平台搭建完整的仿真控制系统。研究内容涵盖四旋翼无人机的动力学建模、状态空间表达、线性与非线性预测模型构建、时域优化求解以及系统约束处理等关键技术环节,重点从轨迹跟踪精度、动态响应速度、系统稳定性及抗干扰能力等方面对两种控制策略进行对比分析,深入探讨线性化近似方法与精确非线性模型在实际控制效果上的差异,为无人机高性能飞控系统的设计提供理论支撑与仿真验证依据; 适合人群:具备自动控制原理、非线性系统理论、无人机动力学及Matlab/Simulink仿真基础的研究生、科研人员以及从事无人飞行器控制算法开发的工程技术人员; 使用场景及目标:① 掌握模型预测控制(MPC)在强非线性系统如四旋翼中的具体应用方法;② 理解LMPC与NMPC在建模假设、优化求解及控制性能上的本质差异;③ 为相关课题的仿真系统搭建、控制算法选型与性能评估提供实践参考;④ 支持课程设计、学位论文撰写或科研项目的算法验证与结果分析; 阅读建议:建议结合提供的Simulink仿真模型,深入剖析状态预测、代价函数设计与实时优化的实现机制,对比不同飞行工况(如高机动轨迹)下的仿真结果,重点关注NMPC在复杂动态环境中的性能优势以及LMPC在计算效率与实时性方面的潜力,同时应注意非线性优化带来的计算负担问题及其对工程可实现性的影响。
内容概要:本文档为一篇关于“基于超局部模型无模型预测电流控制(MFPCC)+自抗扰ESO观测器改进模型预测控制仿真”的论文复现资源,重点介绍了在Simulink环境下对三相逆变器系统进行建模与控制策略仿真的研究。核心内容聚焦于采用无模型预测电流控制(MFPCC)结合自抗扰控制中的扩张状态观测器(ESO)来提升系统对参数不确定性与外部干扰的鲁棒性,优化电流环动态响应性能。文中通过构建超局部模型规避精确系统建模的难题,利用MFPCC实现快速动态响应,并引入ESO实时估计并补偿系统内外部扰动,从而增强整体控制精度与稳定性。通过与传统控制方法的对比仿真,充分验证了该复合控制策略在抑制扰动、提高电流跟踪精度及改善系统鲁棒性方面的优越性,文档同时提供了完整的Simulink仿真模型与实现代码,便于读者复现、调试与深入研究。; 适合人群:具备电力电子、自动控制理论基础,熟悉Simulink仿真环境,从事电机控制、新能源并网、电力变换器控制或预测控制算法研究的研究生、科研人员及工程技术人员。; 使用场景及目标:① 复现并掌握MFPCC与ESO相结合的先进复合控制策略;② 深入研究无模型预测控制在电力电子系统中的具体应用与实现方法;③ 探索自抗扰控制中ESO观测器在扰动估计与补偿、提升系统鲁棒性方面的关键作用与设计要点;④ 作为毕业设计、科研课题、学术论文复现或工程项目开发的重要技术参考与原型验证平台。; 阅读建议:建议读者结合现代控制理论与电力电子技术基础知识,首先深入理解MFPCC的无模型预测原理与ESO的扰动观测机理,再逐步导入并调试所提供的仿真模型,重点关注控制器参数的整定过程、系统在不同工况下的抗扰性能测试与动态响应指标分析,同时可参考文档中列出的其他相关案例进行横向比较与综合学习,以达到融贯通的效果。

87,989

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧