必威-必威-欢迎您

必威,必威官网企业自成立以来,以策略先行,经营致胜,管理为本的商,业推广理念,一步一个脚印发展成为同类企业中经营范围最广,在行业内颇具影响力的企业。

在线演示        必威:源码下载,实现如下图

2019-11-03 18:36 来源:未知

下个版本计划

当前3.1.0版本还存在一些问题:

  1. 由于JS本身存在计算浮点数精度丢失问题,所以这个问题在项目中同意存在,需要自己去处理这个问题
  2. 由于使用了第三方的天气接口,用了jquery.Ajax方法,所以违背了使用纯原生写的初衷。

所以下个版本的开发计划为:

  1. 解决浮点数计算精度问题
  2. 把获取天气信息的jquery.Ajax方法替换为原生JavaScript代码,自己封装JSONP请求函数
  3. 使用面向对象方式重构APP

欢迎大家到github上来看看,如果喜欢可以star、watch一下,或提issue。

4 赞 21 收藏 2 评论

必威 1

HTML5单页面手势滑屏切换原理,html5页面手势原理

H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,效果图如下所示,本文简单说一下其实现原理和主要思路。
1、实现原理 假设有5个页面,每个页面占屏幕100%宽,则创建一个DIV容器viewport,将其宽度(width) 设置为500%,然后将5个页面装入容器中,并让这5个页面平分整个容器,最后将容器的默认位置设置为0,overflow设置为hidden,这样屏幕就默认显示第一个页面。

XML/HTML Code复制内容到剪贴板

  1. <div id="viewport" class="viewport">    
  2. <div class="pageview" style="background: #3b76c0" >    
  3. <h3 >页面-1</h3>    
  4. </div>    
  5. <div class="pageview" style="background: #58c03b;">    
  6. <h3>页面-2</h3>    
  7. </div>    
  8. <div class="pageview" style="background: #c03b25;">    
  9. <h3>页面-3</h3>    
  10. </div>    
  11. <div class="pageview" style="background: #e0a718;">    
  12. <h3>页面-4</h3>    
  13. </div>    
  14. <div class="pageview" style="background: #c03eac;">    
  15. <h3>页面-5</h3>    
  16. </div>    
  17. </div>   

CSS样式:

XML/HTML Code复制内容到剪贴板

  1. .viewport{    
  2. width: 500%;    
  3. height: 100%;    
  4. display: -webkit-box;    
  5. overflow: hidden;    
  6. pointer-events: none;    
  7. -webkit-transform: translate3d(0,0,0);    
  8. backface-visibility: hidden;    
  9. position: relative;    
  10. }  

注册touchstart,touchmove和touchend事件,当手指在屏幕上滑动时,使用CSS3的transform来实时设置viewport的位置,比如要显示第二个页面,就设置viewport的transform:translate3d(100%,0,0) 即可, 在这里我们使用translate3d来代替translateX,translate3d可以主动开启手机GPU加速渲染,页面滑动更流畅。
2、主要思路
从手指放在屏幕上、滑动操作、再到离开屏幕是一个完整的操作过程,对应的操作会触发如下事件:
手指放在屏幕上:ontouchstart
手指在屏幕上滑动:ontouchmove
手指离开屏幕:ontouchend
我们需要捕获触摸事件的这三个阶段来完成页面的滑动:
ontouchstart: 初始化变量, 记录手指所在的位置,记录当前时间

XML/HTML Code复制内容到剪贴板

  1. /*手指放在屏幕上*/    
  2. document.addEventListener("touchstart",function(e){    
  3. e.preventDefault();    
  4. var touch = e.touches[0];    
  5. startX = touch.pageX;    
  6. startY = touch.pageY;    
  7. initialPos = currentPosition; //本次滑动前的初始位置    
  8. viewport.style.webkitTransition = ""; //取消动画效果    
  9. startT = new Date().getTime(); //记录手指按下的开始时间    
  10. isMove = false; //是否产生滑动    
  11. }.bind(this),false);   

ontouchmove: 获得当前所在位置,计算手指在屏幕上的移动差量deltaX,然后使页面跟随移动

XML/HTML Code复制内容到剪贴板

  1. /*手指在屏幕上滑动,页面跟随手指移动*/    
  2. document.addEventListener("touchmove",function(e){    
  3. e.preventDefault();    
  4. var touch = e.touches[0];    
  5. var deltaX = touch.pageX - startX;    
  6. var deltaY = touch.pageY - startY;    
  7. //如果X方向上的位移大于Y方向,则认为是左右滑动    
  8. if (Math.abs(deltaX) > Math.abs(deltaY)){    
  9. moveLength = deltaX;    
  10. var translate = initialPos + deltaX; //当前需要移动到的位置    
  11. //如果translate>0 或 < maxWidth,则表示页面超出边界    
  12. if (translate <=0 && translate >= maxWidth){    
  13. //移动页面    
  14. this.transform.call(viewport,translate);    
  15. isMove = true;    
  16. }    
  17. direction = deltaX>0?"right":"left"; //判断手指滑动的方向    
  18. }    
  19. }.bind(this),false);   

ontouchend:手指离开屏幕时,计算屏幕最终停留在哪一页。首先计算手指在屏幕上的停留时间deltaT,如果deltaT<300ms,则认为是快速滑动,相反则是慢速滑动,快速滑动和慢速滑动的处理是不同的:
(1)如果是快速滑动,则让当前页面完整的停留在屏幕中央(需要计算当前页面还有多少需要滑动)
(2)如果是慢速滑动,还需要判断手指在屏幕上滑动的距离,如果滑动的距离没有超过屏幕宽度50%,则要回退到上一页,相反则要停留在当前页面

XML/HTML Code复制内容到剪贴板

  1. /*手指离开屏幕时,计算最终需要停留在哪一页*/    
  2. document.addEventListener("touchend",function(e){    
  3. e.preventDefault();    
  4. var translate = 0;    
  5. //计算手指在屏幕上停留的时间    
  6. var deltaT = new Date().getTime() - startT;    
  7. if (isMove){ //发生了左右滑动    
  8. //使用动画过渡让页面滑动到最终的位置    
  9. viewport.style.webkitTransition = "0.3s ease -webkit-transform";    
  10. if(deltaT < 300){ //如果停留时间小于300ms,则认为是快速滑动,无论滑动距离是多少,都停留到下一页    
  11. translate = direction == 'left'?    
  12. currentPosition-(pageWidth+moveLength):currentPosition+pageWidth-moveLength;    
  13. //如果最终位置超过边界位置,则停留在边界位置    
  14. translatetranslate = translate > 0 ? 0 : translate; //左边界    
  15. translatetranslate = translate < maxWidth ? maxWidth : translate; //右边界    
  16. }else {    
  17. //如果滑动距离小于屏幕的50%,则退回到上一页    
  18. if (Math.abs(moveLength)/pageWidth < 0.5){    
  19. translate = currentPosition-moveLength;    
  20. }else{    
  21. //如果滑动距离大于屏幕的50%,则滑动到下一页    
  22. translate = direction == 'left'?    
  23. currentPosition-(pageWidth+moveLength):currentPosition+pageWidth-moveLength;    
  24. translatetranslate = translate > 0 ? 0 : translate;    
  25. translatetranslate = translate < maxWidth ? maxWidth : translate;    
  26. }    
  27. }    
  28. //执行滑动,让页面完整的显示到屏幕上    
  29. this.transform.call(viewport,translate);    
  30. }    
  31. }.bind(this),false);   

除此之外,还要计算当前页面是第几页,并设置当前页码

XML/HTML Code复制内容到剪贴板

  1. //计算当前的页码    
  2. pageNow = Math.round(Math.abs(translate) / pageWidth) + 1;    
  3. setTimeout(function(){    
  4. //设置页码,DOM操作需要放到子线程中,否则会出现卡顿    
  5. this.setPageNow();    
  6. }.bind(this),100);   

基本的思路就这些,当然在实际操作过程中还有一些细节需要注意,这里就不详细说了,都在代码里能体现出来。关于HTML5单页面手势滑屏切换原理 小编就给大家介绍这么多,希望对大家有所帮助!

H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,效...

HTML5 SVG环形图表应用 很酷的数据初始动画

很有创意的HTML5图表应用,图表是环形的,初始化时的动画效果也非常不错。

核心jQuery代码:

必威 2$(function(){ $("#doughnutChart").drawDoughnutChart([ { title: "Tokyo", value : 120, color: "#2C3E50" }, { title: "San Francisco", value: 80, color: "#FC4349" }, { title: "New York", value: 70, color: "#6DBCDB" }, { title: "London", value : 50, color: "#F7E248" }, { title: "Sydney", value : 40, color: "#D7DADB" }, { title: "Berlin", value : 20, color: "#FFF" } ]); }); /*! * jquery.drawDoughnutChart.js * Version: 0.3(Beta) * Inspired by Chart.js() * * Copyright 2013 hiro * * Released under the MIT license. * */ ;(function($, undefined) { $.fn.drawDoughnutChart = function(data, options) { var $this = this, W = $this.width(), H = $this.height(), centerX = W/2, centerY = H/2, cos = Math.cos, sin = Math.sin, PI = Math.PI, settings = $.extend({ segmentShowStroke : true, segmentStrokeColor : "#0C1013", segmentStrokeWidth : 1, baseColor: "rgba(0,0,0,0.5)", baseOffset: 4, edgeOffset : 10,//offset from edge of $this percentageInnerCutout : 75, animation : true, animationSteps : 90, animationEasing : "easeInOutExpo", animateRotate : true, tipOffsetX: -8, tipOffsetY: -45, tipClass: "doughnutTip", summaryClass: "doughnutSummary", summaryTitle: "TOTAL:", summaryTitleClass: "doughnutSummaryTitle", summaryNumberClass: "doughnutSummaryNumber", beforeDraw: function() { }, afterDrawed : function() { }, onPathEnter : function(e,data) { }, onPathLeave : function(e,data) { } }, options), animationOptions = { linear : function (t) { return t; }, easeInOutExpo: function (t) { var v = t<.5 ? 8*t*t*t*t : 1-8*(--t)*t*t*t; return (v>1) ? 1 : v; } }, requestAnimFrame = function() { return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60); }; }(); settings.beforeDraw.call($this); var $svg = $('<svg width="' + W + '" height="' + H + '" viewBox="0 0 ' + W + ' ' + H + '" xmlns="" xmlns:xlink="), $paths = [], easingFunction = animationOptions[settings.animationEasing], doughnutRadius = Min([H / 2,W / 2]) - settings.edgeOffset, cutoutRadius = doughnutRadius * (settings.percentageInnerCutout / 100), segmentTotal = 0; //Draw base doughnut var baseDoughnutRadius = doughnutRadius + settings.baseOffset, baseCutoutRadius = cutoutRadius - settings.baseOffset; var drawBaseDoughnut = function() { //Calculate values for the path. //We needn't calculate startRadius, segmentAngle and endRadius, because base doughnut doesn't animate. var startRadius = -1.570,// -Math.PI/2 segmentAngle = 6.2831,// 1 * ((99.9999/100) * (PI*2)), endRadius = 4.7131,// startRadius + segmentAngle startX = centerX + cos(startRadius) * baseDoughnutRadius, startY = centerY + sin(startRadius) * baseDoughnutRadius, endX2 = centerX + cos(startRadius) * baseCutoutRadius, endY2 = centerY + sin(startRadius) * baseCutoutRadius, endX = centerX + cos(endRadius) * baseDoughnutRadius, endY = centerY + sin(endRadius) * baseDoughnutRadius, startX2 = centerX

  • cos(endRadius) * baseCutoutRadius, startY2 = centerY + sin(endRadius) * baseCutoutRadius; var cmd = [ 'M', startX, startY, 'A', baseDoughnutRadius, baseDoughnutRadius, 0, 1, 1, endX, endY, 'L', startX2, startY2, 'A', baseCutoutRadius, baseCutoutRadius, 0, 1, 0, endX2, endY2,//reverse 'Z' ]; $(document.createElementNS('', 'path')) .attr({ "d": cmd.join(' '), "fill": settings.baseColor }) .appendTo($svg); }(); //Set up pie segments wrapper var $pathGroup = $(document.createElementNS('', 'g')); $pathGroup.attr({opacity: 0}).appendTo($svg); //Set up tooltip var $tip = $('<div class="' + settings.tipClass + '" />').appendTo('body').hide(), tipW = $tip.width(), tipH = $tip.height(); //Set up center text area var summarySize = (cutoutRadius
  • (doughnutRadius - cutoutRadius)) * 2, $summary = $('<div class="'
  • settings.summaryClass + '" />') .appendTo($this) .css({ width: summarySize + "px", height: summarySize + "px", "margin-left": -(summarySize / 2) + "px", "margin-top": -(summarySize / 2) + "px" }); var $summaryTitle = $('<p class="' + settings.summaryTitleClass + '">' + settings.summaryTitle + '</p>').appendTo($summary); var $summaryNumber = $('<p class="' + settings.summaryNumberClass + '"></p>').appendTo($summary).css({opacity: 0}); for (var i = 0, len = data.length; i < len; i++) { segmentTotal += data[i].value; $paths[i] = $(document.createElementNS('', 'path')) .attr({ "stroke-width": settings.segmentStrokeWidth, "stroke": settings.segmentStrokeColor, "fill": data[i].color, "data-order": i }) .appendTo($pathGroup) .on("mouseenter", pathMouseEnter) .on("mouseleave", pathMouseLeave) .on("mousemove", pathMouseMove); } //Animation start animationLoop(drawPieSegments); function pathMouseEnter(e) { var order = $(this).data().order; $tip.text(data[order].title + ": " + data[order].value) .fadeIn(200); settings.onPathEnter.apply($(this),[e,data]); } function pathMouseLeave(e) { $tip.hide(); settings.onPathLeave.apply($(this),[e,data]); } function pathMouseMove(e) { $tip.css({ top: e.pageY + settings.tipOffsetY, left: e.pageX - $tip.width() / 2 + settings.tipOffsetX }); } function drawPieSegments (animationDecimal) { var startRadius = -PI / 2,//-90 degree rotateAnimation = 1; if (settings.animation && settings.animateRotate) rotateAnimation = animationDecimal;//count up between0~1 drawDoughnutText(animationDecimal, segmentTotal); $pathGroup.attr("opacity", animationDecimal); //draw each path for (var i = 0, len = data.length; i < len; i++) { var segmentAngle = rotateAnimation * ((data[i].value / segmentTotal) * (PI * 2)), endRadius = startRadius + segmentAngle, largeArc = ((endRadius - startRadius) % (PI * 2)) > PI ? 1 : 0, startX = centerX + cos(startRadius) * doughnutRadius, startY = centerY + sin(startRadius) * doughnutRadius, endX2 = centerX + cos(startRadius) * cutoutRadius, endY2 = centerY + sin(startRadius) * cutoutRadius, endX = centerX + cos(endRadius) * doughnutRadius, endY = centerY + sin(endRadius) * doughnutRadius, startX2 = centerX + cos(endRadius) * cutoutRadius, startY2 = centerY + sin(endRadius) * cutoutRadius; var cmd = [ 'M', startX, startY,//Move pointer 'A', doughnutRadius, doughnutRadius, 0, largeArc, 1, endX, endY,//Draw outer arc path 'L', startX2, startY2,//Draw line path(this line connects outer and innner arc paths) 'A', cutoutRadius, cutoutRadius, 0, largeArc, 0, endX2, endY2,//Draw inner arc path 'Z'//Cloth path ]; $paths[i].attr("d", cmd.join(' ')); startRadius += segmentAngle; } } function drawDoughnutText(animationDecimal, segmentTotal) { $summaryNumber .css({opacity: animationDecimal}) .text((segmentTotal * animationDecimal).toFixed(1)); } function animateFrame(cnt, drawData) { var easeAdjustedAnimationPercent =(settings.animation)? CapValue(easingFunction(cnt), null, 0) : 1; drawData(easeAdjustedAnimationPercent); } function animationLoop(drawData) { var animFrameAmount = (settings.animation)? 1 / CapValue(settings.animationSteps, Number.MAX_VALUE, 1) : 1, cnt =(settings.animation)? 0 : 1; requestAnimFrame(function() { cnt += animFrameAmount; animateFrame(cnt, drawData); if (cnt <= 1) { requestAnimFrame(arguments.callee); } else { settings.afterDrawed.call($this); } }); } function Max(arr) { return Math.max.apply(null, arr); } function Min(arr) { return Math.min.apply(null, arr); } function isNumber(n) { return !isNaN(parseFloat(n)) && isFinite(n); } function CapValue(valueToCap, maxValue, minValue) { if (isNumber(maxValue) && valueToCap > maxValue) return maxValue; if (isNumber(minValue) && valueToCap < minValue) return minValue; return valueToCap; } return $this; }; })(jQuery); View Code

必威 3

在线演示        源码下载

一道笔试题引发的一个练手项目

花了一点时间写好的第一版,符合了笔试题的要求。后来左看右看觉得还可以改进做的更好,于是给它不断的改进,加新功能等,这样下来没完没了,利用业余时间一点一点的写,从刚开始的网页版,到后来做响应式的移动版,再到现在的移动App,短短续续大概写了3个月吧。

纯 HTML+CSS+JavaScript 编写的计算器应用

2016/09/26 · CSS, HTML5, JavaScript · 2 评论 · 计算器

原文出处: dunizb   

HTML5迷你音乐播放器 3D翻转播放按钮

很有创意的HTML5音乐播放器,而且播放按钮还有3D的动画效果,整个播放器也是相当迷你。

核心jQuery代码:

必威 4// Most of this is all Dave Rupert // See (function(){ $(".play-pause").click(function() { if($(this).hasClass('pausing')){ $(this).removeClass('pausing'); $(this).addClass('playing'); $(this).css("background-image", "url()"); audio.play(); } else if($(this).hasClass('playing')){ $(this).removeClass('playing'); $(this).addClass('pausing'); $(this).css("background-image", "url()"); audio.pause(); } else { $(this).addClass('playing'); $(this).css("background-image", "url()"); audio.play(); } }); var pcastPlayers = document.querySelectorAll('.player-container'); var speeds = [ 1, 1.5, 2, 2.5, 3, 0.5 ] for(i=0;i<pcastPlayers.length;i++) { var player = pcastPlayers[i]; var audio = player.querySelector('audio');/* var play = player.querySelector('.play-pause.playing'); var pause = player.querySelector('.play-pause.pausing');*/ var progress = player.querySelector('.pcast-progress'); var currentTime = player.querySelector('.pcast-currenttime'); var currentSpeedIdx = 0; var toHHMMSS = function ( totalsecs ) { var sec_num = parseInt(totalsecs, 10); // don't forget the second param var hours = Math.floor(sec_num / 3600); var minutes = Math.floor((sec_num - (hours * 3600)) / 60); var seconds = sec_num - (hours * 3600) - (minutes * 60); if (hours < 10) {hours = "0"+hours; } if (minutes < 10) {minutes = ""+minutes;} if (seconds < 10) {seconds = "0"+seconds;} var time = hours+':'+minutes+':'+seconds; if (hours <= 1) { var time = minutes+':'+seconds; } return time; } audio.addEventListener('loadedmetadata', function(){ progress.setAttribute('max', Math.floor(audio.duration)); duration.textContent = toHHMMSS(audio.duration); }); audio.addEventListener('timeupdate', function(){ progress.setAttribute('value', audio.currentTime); currentTime.textContent = toHHMMSS(audio.currentTime); }); /* play.addEventListener('click', function(){ this.style.display = 'none'; pause.style.display = 'inline-block'; pause.focus(); audio.play(); }, false); pause.addEventListener('click', function(){ this.style.display = 'none'; play.style.display = 'inline-block'; play.focus(); audio.pause(); }, false); */ progress.addEventListener('click', function(e){ audio.currentTime = Math.floor(audio.duration) * (e.offsetX / e.target.offsetWidth); }, false); } })(this); View Code

必威 5

在线演示        源码下载

一道笔试题

之前偶然看到一个公司的笔试题,题目如下:

用HTML5、CSS3、JavaScript,做一个网页,实现如下图形式计算器

必威 6

具体要求:

  1. 有且只有一个文件:index.html。不允许再有其他文件,不允许再有单独的CSS、JS、PNG、JPG文件。
  2. 运行环境为 Google Chrome。
  3. 必须支持标准的四则运算。例如:1+2*3=7。
  4. 请在收到邮件的48小时内独立完成本测试,并回复本邮件。

CSS3各大网站分享按钮 带网站Logo小图标

这些按钮样式非常丰富,而且还带有网站的Logo,这些超酷的按钮都是利用CSS3实现的。

核心CSS3代码:

必威 7.zocial.icon { overflow: hidden; max-width: 2.4em; padding-left: 0; padding-right: 0; max-height: 2.15em; white-space: nowrap; } .zocial.icon:before { padding: 0; width: 2em; height: 2em; -webkit-box-shadow: none; box-shadow: none; border: none; } .zocial:active { background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(255,255,255,.1)), color-stop(30%, rgba(255,255,255,0)), color-stop(50%, transparent), to(rgba(0,0,0,.1))); background-image: -webkit-linear-gradient(bottom, rgba(255,255,255,.1), rgba(255,255,255,0) 30%, transparent 50%, rgba(0,0,0,.1)); background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(255,255,255,.1)), color-stop(30%, rgba(255,255,255,0)), color-stop(50%, transparent), to(rgba(0,0,0,.1))); background-image: linear-gradient(bottom, rgba(255,255,255,.1), rgba(255,255,255,0) 30%, transparent 50%, rgba(0,0,0,.1)); } View Code

必威 8

在线演示        源码下载

TAG标签:
版权声明:本文由必威发布于必威-前端,转载请注明出处:在线演示        必威:源码下载,实现如下图