Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 日本黄色成年人免费观看,日本国产最新一区二区三区,中文字幕日韩一区二区三区不

          整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          HTML5 Canvas逼真水波紋動畫特效

          多特效代碼請添加HTML5前端交流群581549454

          廢話不多說上代碼!

          normalize.css

          article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block;}audio,canvas,video{display:inline-block;}audio:not([controls]){display:none;height:0;}[hidden]{display:none;}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;}body{margin:0;}a:focus{outline:thin dotted;}a:active,a:hover{outline:0;}h1{font-size:2em;margin:0.67em 0;}abbr[title]{border-bottom:1px dotted;}b,strong{font-weight:bold;}dfn{font-style:italic;}hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0;}mark{background:#ff0;color:#000;}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em;}pre{white-space:pre-wrap;}q{quotes:"1C" "1D" "18" "19";}small{font-size:80%;}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline;}sup{top:-0.5em;}sub{bottom:-0.25em;}img{border:0;}svg:not(:root){overflow:hidden;}figure{margin:0;}fieldset{border:1px solid #c0c0c0;margin:0 2px;padding:0.35em 0.625em 0.75em;}legend{border:0;padding:0;}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0;}button,input{line-height:normal;}button,select{text-transform:none;}button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer;}button[disabled],html input[disabled]{cursor:default;}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0;}input[type="search"]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none;}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0;}textarea{overflow:auto;vertical-align:top;}table{border-collapse:collapse;border-spacing:0;}

          zzsc.css

          body, html { font-size: 100%; padding: 0; margin: 0;}

          /* Reset */

          *,

          *:after,

          *:before {

          -webkit-box-sizing: border-box;

          -moz-box-sizing: border-box;

          box-sizing: border-box;

          }

          /* Clearfix hack by Nicolas Gallagher: http://nicolasgallagher.com/micro-clearfix-hack/ */

          .clearfix:before,

          .clearfix:after {

          content: " ";

          display: table;

          }

          .clearfix:after {

          clear: both;

          }

          body{

          background: #494A5F;

          color: #D5D6E2;

          font-weight: 500;

          font-size: 1.05em;

          font-family: "Microsoft YaHei","Segoe UI", "Lucida Grande", Helvetica, Arial,sans-serif;

          }

          a{ color: rgba(255, 255, 255, 0.6);outline: none;text-decoration: none;-webkit-transition: 0.2s;transition: 0.2s;}

          a:hover,a:focus{color:#74777b;text-decoration: none;}

          網站代碼

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="UTF-8">

          <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

          <meta name="viewport" content="width=device-width, initial-scale=1.0">

          <title>HTML5 Canvas逼真水波紋動畫特效</title>

          <link rel="stylesheet" type="text/css" href="css/normalize.css" />

          <link rel="stylesheet" type="text/css" href="css/zzsc.css">

          <script src="js/jquery-1.11.0.min.js" type="text/javascript"></script>

          <script type="text/javascript" src="js/jquery.waterrippleeffect.min.js"></script>

          <style type="text/css">

          html, body, div, span, applet, object, iframe,

          h1, h2, h3, h4, h5, h6, p, blockquote, pre,

          a, abbr, acronym, address, big, cite, code,

          del, dfn, em, font, img, ins, kbd, q, s, samp,

          small, strike, strong, sub, sup, tt, var,

          b, u, i, center,

          dl, dt, dd, ol, ul, li,

          fieldset, form, label, legend,

          table, caption, tbody, tfoot, thead, tr, th, td {

          margin: 0;

          padding: 0;

          border: 0;

          outline: 0;

          font-size: 100%;

          vertical-align: baseline;

          /*background: transparent;*/

          box-sizing: border-box;

          }

          body {

          overflow: hidden;

          }

          .container{

          width: 480px;

          height: 480px;

          margin:20px auto;

          position: relative;

          }

          .clear {

          clear: both;

          height: 0;

          font-size: 0;

          line-height: 0;

          }

          </style>

          <script>

          $( document ).ready( function() {

          //------------------------------------------------------------------------

          $( '#preloaderDiv' ).delay( 1000 ).fadeTo( 1000 , 0, function() {

          $( this ).css( 'display', 'none' );

          } );

          $( '#startDiv' ).css( 'cursor', 'pointer' ).click( function() {

          //$( this ).css( 'display', 'none' );

          $( this ).delay( 10 ).fadeTo( 1000 , 0, function() {

          $( this ).css( 'display', 'none' );

          } );

          init();

          } );

          //------------------------------------------------------------------------

          function init() {

          //Settings - params for WaterRippleEffect

          var settings = {

          image: './img/SwimmingPool.jpg',//image path

          rippleRadius: 3,//radius of the ripple

          width: 480,//width

          height: 480,//height

          delay: 1,//if auto param === true. 1 === 1 second delay for animation

          auto: true//if auto param === true, animation starts on it′s own

          };

          //------------------------------------------------------------------------

          //standalone

          //init

          var waterRippleEffect = new WaterRippleEffect( document.getElementById( 'holder' ), settings );

          document.getElementById( 'holder' ).style.cursor = 'pointer';

          //on click

          document.getElementById( 'holder' ).addEventListener( 'click', function( e ) {

          var mouseX = e.layerX;

          var mouseY = e.layerY;

          waterRippleEffect.disturb( mouseX, mouseY );

          } );

          //on mousemove

          document.getElementById( 'holder' ).addEventListener( 'mousemove', function( e ) {

          var mouseX = e.layerX;

          var mouseY = e.layerY;

          waterRippleEffect.disturb( mouseX, mouseY );

          } );

          //------------------------------------------------------------------------

          //jQuery

          //init

          /*

          $( '#holder' ).waterRippleEffect( settings );

          $( '#holder' ).css( 'cursor', 'pointer' );

          */

          //on click

          /*

          $( '#holder' ).click( function( e ) {

          var mouseX = e.pageX - $( this ).offset().left;

          var mouseY = e.pageY - $( this ).offset().top;

          $( '#holder' ).waterRippleEffect( "disturb", mouseX, mouseY );

          } );

          */

          //on mousemove

          /*

          $( '#holder' ).mousemove( function( e ) {

          var mouseX = e.pageX - $( this ).offset().left;

          var mouseY = e.pageY - $( this ).offset().top;

          $( '#holder' ).waterRippleEffect( "disturb", mouseX, mouseY );

          } );

          */

          };

          //------------------------------------------------------------------------

          } );

          </script>

          </head>

          <body><script src="/demos/googlegg.js"></script>

          <div>

          <div id='holder' style='width:480px; height:480px; position:absolute;'></div>

          <div id='startDiv' style='background-color:#000; position:absolute; width:480px; height:480px;'>

          <img src='img/startBt.jpg' width='480px' height='480px' alt='Start' style='position:absolute; top:50%; left:50%; margin-top:-240px; margin-left:-240px;'>

          </div>

          <div id='preloaderDiv' style='background-color:#000; position:absolute; width:480px; height:480px; pointer-events:none'>

          <img src='img/PreloaderDark.gif' width='44px' height='48px' alt='Preloader' style='position:absolute; top:50%; left:50%; margin-top:-22px; margin-left:-24px;'>

          </div>

          </div>

          <div style="text-align:center;margin:50px 0; font:normal 14px/24px 'MicroSoft YaHei';">

          <p>適用瀏覽器:360、FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗. 不支持IE8及以下瀏覽器。</p>

          <p>來源:<a target="_blank">素材</a></p>

          </div>

          </body>

          </html>

          SS偽元素主要是指HTML中沒有定義、存在的元素,偽元素本身不是真正的頁面元素,但是偽元素在使用過程中,其用法與效果與其他真正頁面元素是一樣的。偽元素只能在定義基礎上動態顯示其運行效果,在HTML源文件中并沒有該元素的真正代碼。CSS3中所定義的所有偽元素與偽類描述如下圖所示:

          CSS偽元素與偽類


          按鈕波紋ripple效果展示

          ripple波紋

          按鈕的波紋效果主要是指按鈕在點擊時展示出的動態效果。在實現效果過程中可行的方法方式較多,例如可以使用JavaScript、CSS動畫、JQuery等。網上目前按鈕波紋實現效果較多,部分樣式效果展示如下:

          波紋效果展示


          CSS 偽類波紋效果實現

          CSS偽類波紋效果主要借助于before、after偽類與hover懸停選擇器等實現類似波紋效果,本文主要借助after及hover等實現按鈕的波紋效果,本例設計兩種類似波紋效果,最終實現效果展示如下圖所示:

          設計樣式1

          設計樣式2

          本文設計實現的兩類波紋效果樣式描述如上圖gif所示,其實現過程描述如下:

          1、按鈕基本樣式設計

          本例按鈕基本樣式主要包括寬度、高度、背景顏色等。使用元素選擇器與類選擇器定義了按鈕元素的基本樣式,其樣式實現代碼描述如下:

          button,.button2,.button{width: 200px; height: 50px; background-color: green;border: 0; cursor: pointer;color: #FFF; font-size: 16px; position: relative;}
          

          .button類主要用以實現設計樣式1,.button2類主要用于實現設計效果2,兩類按鈕定義描述如下:

          <button type="button" class="button">Ripple1</button>
          <button type="button" class="button2">Ripple2</button>
          

          2、after偽元素使用

          after偽元素主要用于實現在指定元素的后面添加新的內容。本例提供的兩種設計方式都是在button元素的后面添加新的類似div的新元素,其中樣式1,新添加的元素與button本身重合,尺寸也一致。設計樣式2中after元素位于button的底部位置,寬度與button相同,高度為指定尺寸5px。兩個設計中after元素樣式為實現動態展開效果都涉及寬度width為0。after元素的樣式定義如下:

          .button::after{content: " "; width: 0; height: 50px; position: absolute; left:50%;top: 0%;background-color: red;opacity: 0; transition: all .4s; }
          .button2::after{content: " "; width: 0; height: 5px; position: absolute; left:50%;top: 100%;background-color: red;transition: all .4s; }
          

          after元素CSS樣式定義中使用了transition屬性實現動畫效果,即在0.4s內實現寬度從0改變為100%。

          3、hover選擇器的使用

          hover選擇器為懸停選擇器,主要對鼠標在HTML元素懸停時樣式進行設置。本例兩個涉及效果都是借助hover懸停選擇器對after樣式進行設置,在初始化設置寬度為0的基礎上寬度改變為100%,最終實現兩端伸展的效果。hover選擇器定義after元素樣式描述如下所示:

          .button:hover::after{left:0%; width: 100%; opacity: 0.6;}
          .button2:hover::after{left:0%; width: 100%;}
          

          以上給出了CSS偽元素實現波紋效果,主要借助了after、before偽元素與hover懸停選擇器等。設計實現效果完整源文件截圖如下:

          案例完整代碼


          以上給出了JavaScript中的事件基本概念及案例分析,如有問題可在評論區討論。本頭條號長期關注編程資訊分享;編程課程、素材、代碼分享及編程培訓。如果您對以上方面有興趣或代碼錯誤、建議與意見,可以聯系作者,共同探討。期待大家關注!相關文章鏈接如下:

          前端開發-JavaScript中的事件(Event)及事件處理總結

          前端開發-CSS3動畫實現焦點(圖文輪播)圖效果

          前端開發-JavaScript DOM動態生成文本框

          前端設計-教你如何快速繪制HTML5動畫

          前端設計-響應式頁面開發基礎

          前端設計-Ajax技術及實例展示

          天躺在床上刷抖音的時候,看見了一個馬克筆隨便畫星空的視頻,很有意思。


          先看效果:


          開始需求分析:

          1、漸變色的背景

          2、畫一顆樹和一些草

          3、水面的倒影

          4、隨便畫點星星

          5、畫一顆流星


          1、漸變色的背景

          先確定200*500的區域,使用css3的線性漸變屬性,依次深藍、淺藍、紫色、粉色、黃色畫出一個漸變色的背景。

          為了使背景更真實,使用同樣的顏色順序,在不同的角度,加上一些模糊和透明。再畫一遍重疊起來。

          再重疊一層黑色,使畫布更暗一些。

          .bg-color {
            background-image: linear-gradient(170deg, #000093 13%, #9f35ff, #ff8000 70%, #f9f900 );
          }
          .bg-color2 {
            background-image: linear-gradient( 180deg, #000093 13%, #9f35ff, #ff8000 80%, #f9f900 );
            opacity: 0.3;
            filter: blur(6px);
          }
          .bg-color3 {
            background: rgba(0,0,0,.2);
          }


          2、畫一棵樹和草

          使用html來畫一棵樹的話,需要很多個節點,性能和效果都很差。這里使用canvas來畫樹。

          畫樹的教程,公眾號出過好幾次了,這里就不在重寫了。

          基本原理就是,從一個點向一個方向畫一條直線。從終點開始,重新這個流程。期間可以修改一個角度畫出一分支。

          草就更加簡單。隨便在底部畫一些雜亂的直線。

          // 畫一棵樹
          function drawTree(x, y, deg, step, type) {
            var deg1 = step % 2 == 0 ? 0.1 : -0.1;
            var x1 = x + Math.cos(deg + deg1) * (step + 5) * 0.9;
            var y1 = y + Math.sin(deg + deg1) * (step - 1) * 0.9;
            ctx.beginPath();
            ctx.lineWidth = step / 3;
            ctx.moveTo(x, y);
            ctx.lineTo(x1, y1);
            ctx.stroke();
            if (step > 12) {
              ctx.arc(x, y, step / 6, 0, Math.PI * 2);
              ctx.fill();
            }
            if (step < 3 && Math.random() > 0.7) {
              var r = 2 + Math.random() * 2;
              ctx.arc(x1 + Math.random() * 3, y1 + Math.random() * 3, r, r, Math.PI + r);
              ctx.fill();
            }
            step--;
            if (step > 0) {
              drawTree(x1, y1, deg, step, type);
              if (step % 2 == 1 && step < 17)
                drawTree(x1, y1, deg + 0.2, Math.round(step / 1.13));
              if (step % 2 == 0 && step < 17)
                drawTree(x1, y1, deg - 0.2, Math.round(step / 1.13) );
            }
          }


          3、水面的倒影

          最簡單的做法,就是使用canvas.toDataUrl 拿到canvas的圖片數據。在底部放一個反轉的圖片就可以。

          我這里希望水面的倒影可以動起來。

          新建一個canvas,使用ctx.getImageData拿到我們畫好的樹的像素點數據。

          使用正弦給像素的x軸做一些偏移,得到一個新的數據。put到倒影的canvas上。

          在使用requestAnimationFrame,做出一個流暢的左右擺動的倒影動畫。

          最后,在原數據基礎上,增加一些雜色,使得倒影有一些黑白的橫線,模擬水波的高亮。

          var startWave = 0 // 水波起始位置
          // 倒影增加水波紋效果
          function wave(star){
            var newImgData = ctxShadow.createImageData(200,150)
            var pos = 0
            var source = 0
            startWave += 0.2
            start = startWave
            for(var y = 0 ; y < CANVAS_HEIGHT ; y ++) {
              start += 0.5
              for(var x = 0 ; x < CANVAS_WIDTH ; x ++) {
                pos = (y * CANVAS_WIDTH + x) * 4
                source = (y * CANVAS_WIDTH + x + Math.round(Math.sin(start)* 1.5)) * 4
                newImgData.data[pos + 0] = imgData.data[source + 0];
                newImgData.data[pos + 1] = imgData.data[source + 1];
                newImgData.data[pos + 2] = imgData.data[source + 2];
                newImgData.data[pos + 3] = imgData.data[source + 3];
              }
            }
            ctxShadow.putImageData(newImgData,0,0)
            requestAnimationFrame(wave)
          }


          4、畫星空

          這個簡單,就不再寫代碼了,就隨意寫一些白色的div,隨機插入背景上。


          其實到這一步,已經基本上完成了。


          5、加一些流星

          要畫流星,需要畫出一個漸漸變淡變窄的白線。

          這里偷了個懶,在視覺效果上,一個漸漸變淡的白線,人眼看到,就感覺漸漸變窄。

          這里使用白色加透明漸變,畫出一個流星的輪廓。加入從右到左動畫效果。

          再加入一個外包的div,做一下旋轉和縮放。


          效果完成!!!!


          具體效果,建議查看原文。

          代碼倉庫地址:

          https://github.com/shb190802/html5

          演示地址:

          http://suohb.com/demo/win/starrySky.html


          主站蜘蛛池模板: 国产一区风间由美在线观看| 自拍日韩亚洲一区在线| 精品无码国产AV一区二区三区 | 国产一区在线播放| 无码一区18禁3D| 国产精品一区二区久久精品涩爱| 三上悠亚日韩精品一区在线| 亚洲国产成人精品久久久国产成人一区二区三区综 | 中文字幕aⅴ人妻一区二区 | 精品福利一区二区三区免费视频| 中文字幕乱码一区久久麻豆樱花 | 小泽玛丽无码视频一区| 国内精品视频一区二区三区八戒| 精品一区二区视频在线观看| 日韩精品无码免费一区二区三区| 中文字幕在线视频一区| 国模私拍一区二区三区| 成人丝袜激情一区二区| 日本精品一区二区三区在线视频| 精品一区二区三区在线观看l| 成人丝袜激情一区二区| 国模丽丽啪啪一区二区| 亚洲一区无码中文字幕乱码| 日韩在线视频一区二区三区| 精品国产日产一区二区三区| 成人区精品一区二区不卡亚洲| 亚洲国产成人久久一区WWW| 久久亚洲日韩精品一区二区三区| 国产一区二区影院| 色一情一乱一伦一区二区三欧美 | 一区二区视频免费观看| 日韩免费无码视频一区二区三区| 国产精品成人一区无码| 精品国产鲁一鲁一区二区| 制服丝袜一区二区三区| 日韩一区二区精品观看| 欧美av色香蕉一区二区蜜桃小说 | 精品欧洲av无码一区二区| 一区二区视频免费观看| 一区二区视频在线免费观看| 精品人妻一区二区三区四区 |