$(function(){ // function rem(){ // !function(n){ // var e=n.document, // t=e.documentElement, // i=1920, // d=i/100, // o="orientationchange"in n?"orientationchange":"resize", // a=function(){ // if($(window).innerWidth() > 1920){ // $('html').removeAttr('style'); // } else { // var n=t.clientWidth||320;n>1920&&(n=1920); // t.style.fontSize=n/d+"px" // } // }; // e.addEventListener&&(n.addEventListener(o,a,!1),e.addEventListener("DOMContentLoaded",a,!1)) // }(window); // } // rem(); // 防抖方法 function AntiShake(fn,wait){ var timer = null; return function(){ if(timer !== null){ clearTimeout(timer); } timer = setTimeout(fn,wait); }; } AntiShake(onResize, 200); $(window).resize(AntiShake(onResize, 100)); AntiShake(onScroll, 200); $(window).scroll(AntiShake(onScroll, 100)); //wow调用 if (typeof WOW != 'undefined') { var wow = new WOW({ boxClass: 'wow', animateClass: 'animated', offset: 0, mobile: true, live: true }); wow.init(); } //弹出视频播放器 $('.videoBtn').on('click',function(){ var url = $(this).attr('rel'); if(url.indexOf('http') == 0){ $('.videoPlayer').html(''); } else { $('.videoPlayer').html(''); } $('.PopupVideoBox').fadeIn(200); }); //关闭弹出播放器 $('.closeVideo').on('click', function(){ $('.PopupVideoBox').fadeOut(200); $('.videoPlayer').html(''); }); //swiper方法调用 if(typeof Swiper != 'undefined') { //首页banner var defaBanner = new Swiper('.defaBanner', { paginationClickable: true, loop:true, autoplay:4500, autoplayDisableOnInteraction : false, nextButton: '.defaBannerNext', prevButton: '.defaBannerPrev', pagination : '.defaBannerdot', onInit: function(swiper){ }, onTransitionEnd: function(swiper){ } }); //二级栏目适应内容区 var defaSecondLevelColumn = new Swiper('.defaSecondLevelColumn', { paginationClickable: true, slidesPerView:"auto", spaceBetween:0, autoplayDisableOnInteraction : false, }); } // 页面监听窗口 function onResize(){ if($(window).innerWidth() > 1259){ $('html').removeClass('hideScroll'); $('.defaSearch span').removeClass('closeSearchbox'); $('.defanav ul li p, .defanav, .defaSearchbox,.defaLanguage p').removeAttr('style'); } } //滚动条监听 function onScroll(){ var scrollTop = $(window).scrollTop(); if(scrollTop > $('.header').height()){ $('.defaheader').addClass('defaheaderbg'); } else { $('.defaheader').removeClass('defaheaderbg'); } } //其他事件 $('.defaheader').hover(function(){ $(this).addClass('defaheaderbg'); },function(){ if($(window).scrollTop() < $('.defaheader').height()){ $(this).removeClass('defaheaderbg'); } }); $('.defanav ul li i').on('click',function(){ if($(this).next().is(':hidden')){ $(this).parent().siblings().find('p').slideUp(200); $(this).parent().siblings().removeClass('cur'); $(this).next().slideDown(200); $(this).parent().addClass('cur'); } else { $(this).next().slideUp(200); $(this).parent().removeClass('cur'); } }); $('.defanavbtn').on('click',function(){ if($('.defanav').is(':hidden')){ $(this).addClass('defacloseNavbtn'); $('.defanav').slideDown(200); $('html').addClass('hideScroll'); $('.defaSearchbox').hide(); $('.defaSearch span').removeClass('closeSearchbox'); $('.defaLanguage p').hide(); } else { $(this).removeClass('defacloseNavbtn'); $('.defanav').slideUp(200); $('html').removeClass('hideScroll'); } }); $('.defaSearch span').on('click', function(){ if(window.innerWidth < 1260){ if($(this).next().is(':hidden')){ $(this).addClass('closeSearchbox'); $(this).next().slideDown(200); $('.defanav').hide(); $('.defanavbtn').removeClass('defacloseNavbtn'); $('.defaLanguage p').hide(); } else { $(this).removeClass('closeSearchbox'); $(this).next().slideUp(200); } } }); $('.defaLanguage span').on('click', function(){ if(window.innerWidth < 1260){ if($(this).next().is(':hidden')){ $(this).addClass('closeSearchbox'); $(this).next().slideDown(200); $('.defanav').hide(); $('.defanavbtn').removeClass('defacloseNavbtn'); $('.defaSearchbox').hide(); $('.defaSearch span').removeClass('closeSearchbox'); } else { $(this).removeClass('closeSearchbox'); $(this).next().slideUp(200); } } }); // //省市区选择器 // if (returnCitySN) { // $('#ThreeLevelLinkage').citys({ // code: returnCitySN['cid'], // crossDomain: true, // province:440000, // city:440300, // area:440304, // }); // $('.ChooseCity').select2({ // language: { // noResults: function(params) { // return "暂无数据"; // } // }, // minimumResultsForSearch: Infinity // }); // } // //单项选择器 // $('.individual').select2({ // language: { // noResults: function(params) { // return "暂无数据"; // } // }, // minimumResultsForSearch: Infinity // }); if ($("#grid").length > 0) { int(); function int(){ new AnimOnScroll(document.getElementById('grid'), { minDuration: 0.4, maxDuration: 0.7, viewportFactor: 0.2 }); } $('.WaterfallFlowMore').on('click',function(){ var html = '
  • 2020.10.13

    1从路人甲到C位咖,完美就要这么“妆”!

    作为社会人,每个人都要与他人往来和接触,总有见一面的时候,总会产生或好或坏的第一印象,就第一印象而言,谁都只有一次机会...

  • 2020.10.13

    2从路人甲到C位咖,完美就要这么“妆”!

    作为社会人,每个人都要与他人往来和接触,总有见一面的时候,总会产生或好或坏的第一印象,就第一印象而言,谁都只有一次机会...

  • '; $('.WaterfallFlow ul').append(html); int(); }); } }); // !function(n){ // var e=n.document, // t=e.documentElement, // i=1920, // d=i/100, // o="orientationchange"in n?"orientationchange":"resize", // a=function(){ // var n = t.clientWidth || 320; // //n < 992 && (n = n * 2); // if(n>=1260){ // t.style.fontSize=n/d+"px"; // }else{ // t.style.fontSize="100px"; // } // $('.main').css({'visibility':'visible'}); // }; // e.addEventListener&&(n.addEventListener(o,a,!1),e.addEventListener("DOMContentLoaded",a,!1)) // }(window); $(function () { //swiper方法调用 if (typeof Swiper != 'undefined') { var index_swiper = new Swiper('.index_swiper', { speed: 600, autoplay: 6000, autoplayDisableOnInteraction: false, paginationClickable: true, pagination: '.insw_pagination', noSwiping: true, loop:true, prevButton: '.index_prev', nextButton: '.index_next', autoHeight: true, onInit: function (swiper) { TVideo(swiper); }, onSlideChangeEnd: function (swiper) { TVideo(swiper); } }); function TVideo(abj) { var Video = $(".index_swiper .swiper-slide-active video").get(0) if ($(".index_swiper .swiper-slide-active").find("video").length > 0) { Video.play(); abj.stopAutoplay(); Video.addEventListener('ended', function () { abj.startAutoplay(); }) } } $(".swiper_off i").click(function () { if ($(this).hasClass("cur")) { $(this).removeClass("cur") index_swiper.startAutoplay(); $(this).addClass("icon_stop").removeClass("icon_bofang2"); } else { $(this).addClass("cur") index_swiper.stopAutoplay(); $(this).addClass("icon_bofang2").removeClass("icon_stop"); } }); var inproduct_swiper = new Swiper('.inproduct_swiper', { speed: 600, // pagination: '.inpro_pagination', scrollbarDraggable: true, paginationType: 'progress', slidesPerView: 2, slidesPerColumn: 2, paginationClickable: true, scrollbar: '.inproduct_scrollbar', scrollbarHide: false, spaceBetween: 60, breakpoints: { 1600:{ spaceBetween: 30, }, 992: { spaceBetween: 20, }, 580: { spaceBetween: 10, slidesPerView: 1, } } }); // var purpose_tabSwiper3; var purpose_swiper; // purpose_tabSwiper3 = new Swiper('.purpose_tabSwiper3', { // slidesPerView:8, // spaceBetween: 30, // breakpoints:{ // 992: { // spaceBetween: 5, // }, // 765: { // slidesPerView: 3, // }, // 465: { // slidesPerView:2, // }, // } // }); // purpose_contswiper = new Swiper('.purpose_contswiper', { // speed: 600, // onSlideChangeStart: function (swiper) { // purpose_swiper.slideTo(swiper.activeIndex, 1000, false); // $(".purpose_tab .swiper-slide").eq(swiper.activeIndex).addClass("active").siblings().removeClass("active"); // purpose_tabSwiper3.slideTo(swiper.activeIndex, 1000, false); // } // }); purpose_swiper = new Swiper('.purpose_swiper', { speed: 600, onSlideChangeStart: function (swiper) { // purpose_contswiper.slideTo(swiper.activeIndex, 1000, false); $(".purpose_tab .item").eq(swiper.activeIndex).addClass("active").siblings().removeClass("active"); // purpose_tabSwiper3.slideTo(swiper.activeIndex, 1000, false); $(".home3TabItem").eq(swiper.activeIndex).show().addClass("active").siblings().hide().removeClass("active"); } }); $(".home3TabItem").eq(0).show(); $(".purpose_tab .item").click(function () { var index = $(this).index(); $(this).addClass("active").siblings().removeClass("active"); $(".home3TabItem").eq(index).show().addClass("active").siblings().hide().removeClass("active"); purpose_swiper.slideTo(index, 1000, false); }); $(".purpose_prev").click(function () { purpose_swiper.slidePrev(); }); $(".purpose_next").click(function () { purpose_swiper.slideNext(); }); var incase_swiper1 = new Swiper('.incase_swiper1', { speed: 600, onSlideChangeStart: function (swiper) { $(".incase_tablist .item").eq(swiper.activeIndex).addClass("active").siblings().removeClass("active"); } }); var incase_swiper2 = new Swiper('.incase_swiper2', { speed: 600, observer:true, observeParents:true, onSlideChangeStart: function (swiper) { $(".incase_tablist .item").eq(swiper.activeIndex).addClass("active").siblings().removeClass("active"); } }); $(".incase_tablist .item").hover(function () { var index = $(this).index(); $(this).addClass("active").siblings().removeClass("active") if ($(".incase_swiper").length > 1) { incase_swiper1.slideTo(index, 1000, false); incase_swiper2.slideTo(index, 1000, false); } }); } $(".hsearch_btn").click(function () { if (!$(this).hasClass("active")) { $(this).addClass("active") $("#search-form").css({ "max-height": "60px" }); } else { $(this).removeClass("active") $("#search-form").css({ "max-height": "0" }); } }); $(window).scroll(function () { scrollEvent(); var TopLi = $(window).scrollTop() + 300 $(".Solution_XQ .box").each(function(){ var num = $(this).index() var _this = $(this).offset().top if(TopLi >= _this){ $(".AnchorLocation .con .li").eq(num).addClass("active").siblings().removeClass("active") } }) }); function scrollEvent() { var scrollT = $(window).scrollTop(); if (scrollT > 600) { $("#ScrollTop").addClass("active") $('.cebian').stop().addClass("active"); } else { $("#ScrollTop").removeClass("active"); $('.cebian').stop().removeClass("active"); } } $(".navmenu_div").click(function () { if (!$(this).hasClass("closeNavbtn")) { $(".head_navlist").stop().slideDown(); $(this).addClass("closeNavbtn"); $(".header").addClass("header_active"); $("body").css({ "overflow": "hidden" }); } else { $(".head_navlist").stop().slideUp(); $(this).removeClass("closeNavbtn"); $("body").css({ "overflow-y": "auto" }); } }); $(".head_navlist ul li>span").click(function () { $(this).parent("li").siblings().find(".sub_zinav").stop().slideUp(); $(this).parent("li").siblings().find("span").removeClass("cur") $(this).siblings(".sub_zinav ").find(".sub_zinav3").stop().slideUp(); $(this).siblings(".sub_zinav ").find("i").removeClass("active"); if (!$(this).hasClass("cur")) { $(this).siblings(".sub_zinav").stop().slideDown(); $(this).addClass("cur"); } else { $(this).siblings(".sub_zinav").stop().slideUp(); $(this).removeClass("cur"); } }) var window_width = $(window).innerWidth(); if (window_width >= 992) { var B ; $(".head_navlist li").on("mouseleave",function(){ var that = $(this) B = setTimeout(function () { that.find(".sub_zinav").hide(); }, 800); }); $(".sub_zinav2").on("mouseleave",function(){ $(this).find("i").removeClass("active"); var that = $(this) B = setTimeout(function () { that.find(".sub_zinav3").hide(); }, 800); }); $(".sub_zinav2").on("mouseenter",function(){ $(this).find("i").addClass("active"); $(this).find(".sub_zinav3").stop().slideDown(); $(".ProductNav").stop().hide() clearTimeout(B); }); $(".head_navlist li a").on("mouseenter",function(){ $(this).siblings(".sub_zinav").stop().slideDown(); $(this).parent("li").siblings().find(".sub_zinav").hide() clearTimeout(B); if($(this).siblings(".ProductNav").length > 0){ $(this).siblings(".Lhide").hide(); }else{ $(this).parent("li").siblings().find(".ProductNav").hide() } }); $(".head_navlist li a").on("mouseleave",function(){ clearTimeout(B); }) }else{ $(".sub_zinav2 .Link2").click(function(){ $(this).siblings("i").toggleClass("active"); $(this).siblings(".sub_zinav3").stop().slideToggle(); $(this).parent().siblings().find("i").removeClass("active").siblings(".sub_zinav3").stop().slideUp() }) } $(".footer_nav .iconfontdown").click(function () { if ($(this).hasClass("active")) { $(this).parent("dl").find("dd").stop().slideUp() $(this).removeClass("active") } else { $(this).parent("dl").find("dd").stop().slideDown() $(this).addClass("active") $(this).parent("dl").siblings().find(".footerNav3").stop().slideUp() $(this).parent("dl").siblings().find("dd").stop().slideUp() $(this).parent("dl").siblings().find("i").removeClass("active") } }) if ($(window).innerWidth() <= 992) { $(".footerNav2").click(function(){ if($(this).find("i").hasClass("active")){ $(this).find("i").removeClass("active") $(this).find(".footerNav3").stop().slideUp() }else{ $(this).find("i").addClass("active") $(this).find(".footerNav3").stop().slideDown() $(this).siblings().find("i").removeClass("active") $(this).siblings().find(".footerNav3").stop().slideUp() } }) } $(".submenu_box .submenu_curtitle").click(function(){ if(!$(this).hasClass("cur")){ $(this).addClass("cur") $(".submenu_box_list").stop().slideDown(); }else{ $(this).removeClass("cur") $(".submenu_box_list").stop().slideUp(); } }); $(".innew_tab .item").click(function(){ var index=$(this).index(); $(this).addClass("active").siblings().removeClass("active") $(".innew_list .innew_item").eq(index).css("display","flex").siblings().css("display","none") }); setHeader() ifwidth(); }); function setHeader() { var initHeight = $(document).scrollTop(); if (initHeight > 0) { $(".header").addClass("header_active"); } $(window).scroll(function () { var b = $(document).scrollTop(); if (b <= 60) { $('.header').removeClass("header_active"); } else { $('.header').addClass("header_active"); } }) } function ifwidth() { var window_width = $(window).innerWidth(); if (window_width >= 768) { $(".index_townlist").addClass("swiper-no-swiping") $(".purpose_swiper").addClass("swiper-no-swiping") $(".incase_swiper").addClass("swiper-no-swiping") } } $(function () { $(".publicLeft .li h5").click(function () { if($(this).parent(".li").hasClass("active2")){ $(this).parent(".li").removeClass("active2") $(this).removeClass("active") $(this).siblings(".li2,.Downul2").stop().slideUp().children("h5").removeClass("active") }else if($(this).parent(".li").hasClass("active")){ $(this).parent(".li").removeClass("active") $(this).removeClass("active") $(this).siblings(".li2,.Downul2").stop().slideUp().children("h5").removeClass("active") }else{ $(this).parent(".li").addClass("active") $(this).addClass("active") $(this).siblings(".li2,.Downul2").stop().slideDown() } }) $(".publicLeft .li .ul2 .li3 .t").click(function () { $(this).toggleClass("active") $(this).parents(".ul2").siblings().find(".t").removeClass("active") $(this).parents(".ul2").siblings().find(".ul3").stop().slideUp() $(this).siblings(".ul3").stop().slideToggle() }) // $(".ProTabCont .tabItem").eq(0).show(); $(".ProTabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".ProTabBar .tabTerm").index(this); $(".ProTabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active"); var hei = $(".ProTabCont .tabItem").eq(num).height() + 70 $(".ProductNav").height(hei) }) var window_width = $(window).innerWidth(); if (window_width > 992) { var B ; $(".header .ProductNavOff a").on("mouseenter",function(){ $(".ProductNav").stop().slideDown() $("body").addClass("active") clearTimeout(B); }); $(".ProductNav").on("mouseenter",function(){ clearTimeout(B); }) $(".header .ProductNavOff a").on("mouseleave",function(){ clearTimeout(B); }) $(".header .ProductNavOff").on("mouseleave",function(){ B = setTimeout(function () { $(".ProductNav").hide() }, 800); $("body").removeClass("active") }); $(".header .ProductNav i").on("mouseenter",function(){ B = setTimeout(function () { $(".ProductNav").stop().hide() }, 800); $("body").removeClass("active") }); } if (window_width < 768) { // $(".publicLeft .li").removeClass("active") } /*视频播放*/ var myVideo=document.getElementById("Video1"); $('.TopicPageCon2 .off').on('click',function(){ if (myVideo.paused) { setTimeout(() => { myVideo.play(); }, 10 ); $(this).children("img").hide(); }else { setTimeout(() => { myVideo.pause(); }, 10 ); $(this).children("img").show(); } }) /*视频播放*/ var myVideo2=document.getElementById("Video2"); $('.big_video .off').on('click',function(){ if (myVideo2.paused) { setTimeout(() => { myVideo2.play(); }, 10 ); $(this).children("img").hide(); $(this).siblings(".text").hide(); }else { setTimeout(() => { myVideo2.pause(); }, 10 ); $(this).children("img").show(); $(this).siblings(".text").show(); } }) if (typeof BeerSlider != 'undefined') { $('.slider').each(function(){ new BeerSlider(this); }); } new Swiper('.SolutionXQ_swiper', { speed: 600, slidesPerView: 3, spaceBetween: 20, scrollbar:'.SolutionXQ_scrollbar', breakpoints:{ 992: { spaceBetween: 10, }, 765: { spaceBetween: 10, slidesPerView: 2, }, 465: { spaceBetween: 10, slidesPerView: 1, } } }); $('.AnchorLocation .li').click(function() { $(this).addClass("active").siblings().removeClass("active") var num = $(this).index(); $('html,body').animate({ scrollTop: $('.Solution_XQ .box').eq(num).offset().top - 50 }, 500) }); var CXQswiper1 = new Swiper('.classicCase_XQswiper1', { speed: 600, slidesPerView: 1, onSlideChangeEnd: function(swiper){ var num = CXQswiper1.activeIndex; $(".classicCase_XQswiper2 .swiper-slide").eq(num).addClass("active").siblings().removeClass("active") } }); var CXQswiper2 = new Swiper('.classicCase_XQswiper2', { speed: 600, slidesPerView: 6, spaceBetween: 12, breakpoints:{ 992: { slidesPerView: 5, spaceBetween: 8, }, 765: { spaceBetween:5, slidesPerView: 4, }, 465: { spaceBetween:5, slidesPerView: 3, } } }); $(".classicCase_XQswiper2 .swiper-slide").on("click",function(){ var num = $(this).index() CXQswiper1.slideTo(num, 1000, false);//切换到第一个slide,速度为1秒 $(this).addClass("active").siblings().removeClass("active") }) //tab切换 $(".ServiceTabCont .tabItem").eq(0).show(); $(".ServiceTabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".ServiceTabBar .tabTerm").index(this); $(".ServiceTabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active") }) new Swiper('.News_swiper', { effect : 'fade', speed: 600, autoplay : 4000, pagination: '.News_pagination', paginationClickable :true, breakpoints:{ 765: { autoHeight: true, }, } }); var aboutUsCon6_swiper = new Swiper('.aboutUsCon6_swiper', { slidesPerView:5, // autoplay : 4000, speed:500, // loop:true, prevButton:'.aboutCon6_prev', nextButton:'.aboutCon6_next', breakpoints:{ 992: { slidesPerView: 4, }, 765: { slidesPerView: 3, }, 465: { slidesPerView: 2, } }, onSlideChangeStart: function(swiper){ $(".aboutUsCon6_swiper .swiper-slide").eq(swiper.activeIndex).addClass("active").siblings().removeClass("active") $(".aboutUs .con6 .box .li").eq(swiper.realIndex).addClass("active").siblings().removeClass("active") } }); $(".aboutUs .con6 .aboutUsCon6_swiper .swiper-slide").on('click',function(){ var num =$(this).index(); $(this).addClass("active").siblings().removeClass("active") $(".aboutUs .con6 .box .li").eq(num).addClass("active").siblings().removeClass("active") console.log(num) }) new Swiper('.aboutUsCon7_swiper', { slidesPerView:4, spaceBetween: 20, autoplay : 4000, scrollbar:'.aboutUsCon7_scrollbar', breakpoints:{ 992: { slidesPerView: 3, }, 765: { slidesPerView: 2, }, } }); //tab切换 $(".Case_bigTabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".Case_bigTabBar .tabTerm").index(this); $(".Case_bigTabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active") }) $(".Z6TopicPage6TabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".Z6TopicPage6TabBar .tabTerm").index(this); $(".Z6TopicPage6TabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active") }) $(".Case_CCETabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".Case_CCETabBar .tabTerm").index(this); $(".Case_CCETabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active") }) new Swiper('.PastHighlights_swiper', { slidesPerView:3, spaceBetween: 30, prevButton:'.PastHighlights_prev', nextButton:'.PastHighlights_next', breakpoints:{ 992: { spaceBetween: 10, }, 765: { slidesPerView: 2, }, 465: { slidesPerView: 1, }, } }); // $(".TopicPageCon8").on('click',function(){ // console.log("点击了") // $(".tipsbox").hide(); // }); $(".home4TabBar .tabTerm").click(function(){ $(this).addClass('active'); $(this).siblings().removeClass("active"); var num =$(".home4TabBar .tabTerm").index(this); $(".home4TabCont .tabItem").eq(num).addClass("active").siblings().removeClass("active") }) $(".publicLeft i").on("click",function(){ if($(this).hasClass("active")){ $(this).removeClass("active") $(this).siblings(".li:not(:nth-child(2))").slideUp() // $(this).siblings(".li.active").slideDown() }else{ $(this).addClass("active") $(this).siblings(".li").slideDown() } }) }) $(function(){ $(".TopicPageCon8").click(function(){ console.log('1') $(".tipsbox").hide(); }); if($(".waves").length>0){ class ShaderProgram { constructor( holder, options = {} ) { options = Object.assign( { antialias: false, depthTest: false, mousemove: false, autosize: true, side: 'front', vertex: ` precision highp float; attribute vec4 a_position; attribute vec4 a_color; uniform float u_time; uniform vec2 u_resolution; uniform vec2 u_mousemove; uniform mat4 u_projection; varying vec4 v_color; void main() { gl_Position = u_projection * a_position; gl_PointSize = (10.0 / gl_Position.w) * 100.0; v_color = a_color; }`, fragment: ` precision highp float; uniform sampler2D u_texture; uniform int u_hasTexture; varying vec4 v_color; void main() { if ( u_hasTexture == 1 ) { gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord); } else { gl_FragColor = v_color; } }`, uniforms: {}, buffers: {}, camera: {}, texture: null, onUpdate: ( () => {} ), onResize: ( () => {} ), }, options ) var uniforms = Object.assign( { time: { type: 'float', value: 0 }, hasTexture: { type: 'int', value: 0 }, resolution: { type: 'vec2', value: [ 0, 0 ] }, mousemove: { type: 'vec2', value: [ 0, 0 ] }, projection: { type: 'mat4', value: [ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ] }, }, options.uniforms ) var buffers = Object.assign( { position: { size: 3, data: [] }, color: { size: 4, data: [] }, }, options.buffers ) var camera = Object.assign( { fov: 60, near: 1, far: 10000, aspect: 1, z: 100, perspective: true, }, options.camera ) var canvas = document.createElement( 'canvas' ) var gl = canvas.getContext( 'webgl', { antialias: options.antialias } ) if ( ! gl ) return false this.count = 0 this.gl = gl this.canvas = canvas this.camera = camera this.holder = holder this.onUpdate = options.onUpdate this.onResize = options.onResize this.data = {} holder.appendChild( canvas ) this.createProgram( options.vertex, options.fragment ) this.createBuffers( buffers ) this.createUniforms( uniforms ) this.updateBuffers() this.updateUniforms() this.createTexture( options.texture ) gl.enable( gl.BLEND ) gl.enable( gl.CULL_FACE ) gl.blendFunc( gl.SRC_ALPHA, gl.ONE ) gl[ options.depthTest ? 'enable' : 'disable' ]( gl.DEPTH_TEST ) if ( options.autosize ) window.addEventListener( 'resize', e => this.resize( e ), false ) if ( options.mousemove ) window.addEventListener( 'mousemove', e => this.mousemove( e ), false ) this.resize() this.update = this.update.bind( this ) this.time = { start: performance.now(), old: performance.now() } this.update() } mousemove( e ) { var x = e.pageX / this.width * 2 - 1 var y = e.pageY / this.height * 2 - 1 this.uniforms.mousemove = [ x, y ] } resize( e ) { var holder = this.holder var canvas = this.canvas var gl = this.gl var width = this.width = holder.offsetWidth var height = this.height = holder.offsetHeight var aspect = this.aspect = width / height var dpi = this.dpi = devicePixelRatio canvas.width = width * dpi canvas.height = height * dpi canvas.style.width = width + 'px' canvas.style.height = height + 'px' gl.viewport( 0, 0, width * dpi, height * dpi ) gl.clearColor( 0, 0, 0, 0 ) this.uniforms.resolution = [ width, height ] this.uniforms.projection = this.setProjection( aspect ) this.onResize( width, height, dpi ) } setProjection( aspect ) { var camera = this.camera if ( camera.perspective ) { camera.aspect = aspect var fovRad = camera.fov * ( Math.PI / 180 ) var f = Math.tan( Math.PI * 0.5 - 0.5 * fovRad ) var rangeInv = 1.0 / ( camera.near - camera.far ) var matrix = [ f / camera.aspect, 0, 0, 0, 0, f, 0, 0, 0, 0, (camera.near + camera.far) * rangeInv, -1, 0, 0, camera.near * camera.far * rangeInv * 2, 0 ] matrix[ 14 ] += camera.z matrix[ 15 ] += camera.z return matrix } else { return [ 2 / this.width, 0, 0, 0, 0, -2 / this.height, 0, 0, 0, 0, 1, 0, -1, 1, 0, 1, ] } } createShader( type, source ) { var gl = this.gl var shader = gl.createShader( type ) gl.shaderSource( shader, source ) gl.compileShader( shader ) if ( gl.getShaderParameter (shader, gl.COMPILE_STATUS ) ) { return shader } else { console.log( gl.getShaderInfoLog( shader ) ) gl.deleteShader( shader ) } } createProgram( vertex, fragment ) { var gl = this.gl var vertexShader = this.createShader( gl.VERTEX_SHADER, vertex ) var fragmentShader = this.createShader( gl.FRAGMENT_SHADER, fragment ) var program = gl.createProgram() gl.attachShader( program, vertexShader ) gl.attachShader( program, fragmentShader ) gl.linkProgram( program ) if ( gl.getProgramParameter( program, gl.LINK_STATUS ) ) { gl.useProgram( program ) this.program = program } else { console.log( gl.getProgramInfoLog( program ) ) gl.deleteProgram( program ) } } createUniforms( data ) { var gl = this.gl var uniforms = this.data.uniforms = data var values = this.uniforms = {} Object.keys( uniforms ).forEach( name => { var uniform = uniforms[ name ] uniform.location = gl.getUniformLocation( this.program, 'u_' + name ) Object.defineProperty( values, name, { set: value => { uniforms[ name ].value = value this.setUniform( name, value ) }, get: () => uniforms[ name ].value } ) } ) } setUniform( name, value ) { var gl = this.gl var uniform = this.data.uniforms[ name ] uniform.value = value switch ( uniform.type ) { case 'int': { gl.uniform1i( uniform.location, value ) break } case 'float': { gl.uniform1f( uniform.location, value ) break } case 'vec2': { gl.uniform2f( uniform.location, ...value ) break } case 'vec3': { gl.uniform3f( uniform.location, ...value ) break } case 'vec4': { gl.uniform4f( uniform.location, ...value ) break } case 'mat2': { gl.uniformMatrix2fv( uniform.location, false, value ) break } case 'mat3': { gl.uniformMatrix3fv( uniform.location, false, value ) break } case 'mat4': { gl.uniformMatrix4fv( uniform.location, false, value ) break } } // ivec2 : uniform2i, // ivec3 : uniform3i, // ivec4 : uniform4i, // sampler2D : uniform1i, // samplerCube : uniform1i, // bool : uniform1i, // bvec2 : uniform2i, // bvec3 : uniform3i, // bvec4 : uniform4i, } updateUniforms() { var gl = this.gl var uniforms = this.data.uniforms Object.keys( uniforms ).forEach( name => { var uniform = uniforms[ name ] this.uniforms[ name ] = uniform.value } ) } createBuffers( data ) { var gl = this.gl var buffers = this.data.buffers = data var values = this.buffers = {} Object.keys( buffers ).forEach( name => { var buffer = buffers[ name ] buffer.buffer = this.createBuffer( 'a_' + name, buffer.size ) Object.defineProperty( values, name, { set: data => { buffers[ name ].data = data this.setBuffer( name, data ) if ( name == 'position' ) this.count = buffers.position.data.length / 3 }, get: () => buffers[ name ].data } ) } ) } createBuffer( name, size ) { var gl = this.gl var program = this.program var index = gl.getAttribLocation( program, name ) var buffer = gl.createBuffer() gl.bindBuffer( gl.ARRAY_BUFFER, buffer ) gl.enableVertexAttribArray( index ) gl.vertexAttribPointer( index, size, gl.FLOAT, false, 0, 0 ) return buffer } setBuffer( name, data ) { var gl = this.gl var buffers = this.data.buffers if ( name == null && ! gl.bindBuffer( gl.ARRAY_BUFFER, null ) ) return gl.bindBuffer( gl.ARRAY_BUFFER, buffers[ name ].buffer ) gl.bufferData( gl.ARRAY_BUFFER, new Float32Array( data ), gl.STATIC_DRAW ) } updateBuffers() { var gl = this.gl var buffers = this.buffers Object.keys( buffers ).forEach( name => buffers[ name ] = buffer.data ) this.setBuffer( null ) } createTexture( src ) { var gl = this.gl var texture = gl.createTexture() gl.bindTexture( gl.TEXTURE_2D, texture ) gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, 1, 1, 0, gl.RGBA, gl.UNSIGNED_BYTE, new Uint8Array( [ 0, 0, 0, 0 ] ) ) this.texture = texture if ( src ) { this.uniforms.hasTexture = 1 this.loadTexture( src ) } } loadTexture( src ) { var gl = this.gl var texture = this.texture var textureImage = new Image() textureImage.onload = () => { gl.bindTexture( gl.TEXTURE_2D, texture ) gl.texImage2D( gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, textureImage ) gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR ) gl.texParameteri( gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR ) gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE) gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE) // gl.generateMipmap( gl.TEXTURE_2D ) } textureImage.src = src } update() { var gl = this.gl var now = performance.now() var elapsed = ( now - this.time.start ) / 5000 var delta = now - this.time.old this.time.old = now this.uniforms.time = elapsed if ( this.count > 0 ) { gl.clear( gl.COLORBUFFERBIT ) gl.drawArrays( gl.POINTS, 0, this.count ) } this.onUpdate( delta ) requestAnimationFrame( this.update ) } } var pointSize = 2.5 var waves = new ShaderProgram( document.querySelector( '.waves' ), { texture: '', uniforms: { size: { type: 'float', value: pointSize }, field: { type: 'vec3', value: [ 0, 0, 0 ] }, speed: { type: 'float', value: 5 }, }, vertex: ` #define M_PI 3.1415926535897932384626433832795 precision highp float; attribute vec4 a_position; attribute vec4 a_color; uniform float u_time; uniform float u_size; uniform float u_speed; uniform vec3 u_field; uniform mat4 u_projection; varying vec4 v_color; void main() { vec3 pos = a_position.xyz; pos.y += ( cos(pos.x / u_field.x * M_PI * 8.0 + u_time * u_speed) + sin(pos.z / u_field.z * M_PI * 8.0 + u_time * u_speed) ) * u_field.y; gl_Position = u_projection * vec4( pos.xyz, a_position.w ); gl_PointSize = ( u_size / gl_Position.w ) * 100.0; v_color = a_color; }`, fragment: ` precision highp float; uniform sampler2D u_texture; varying vec4 v_color; void main() { gl_FragColor = v_color * texture2D(u_texture, gl_PointCoord); }`, onResize( w, h, dpi ) { var position = [], color = [] var width = 400 * ( w / h ) var depth = 400 var height = 3 var distance = 5 for ( var x = 0; x < width; x += distance ) { for ( var z = 0; z < depth; z+= distance ) { position.push( - width / 2 + x, -30, -depth / 2 + z ) color.push( 0, 1 - ( x / width ) * 1, 0.5 + x / width * 0.5, z / depth ) } } this.uniforms.field = [ width, height, depth ] this.buffers.position = position this.buffers.color = color this.uniforms.size = ( h / 400) * pointSize * dpi }, } ) } }); $body = (window.opera) ? (document.compatMode == "CSS1Compat" ? $("html") : $("body")) : $("html,body"); $("#ScrollTop").click(function () { $body.animate({ scrollTop: 0 }, 400) });