diff --git a/src/js/layout.js b/src/js/layout.js
new file mode 100644
index 0000000..c5d47e2
--- /dev/null
+++ b/src/js/layout.js
@@ -0,0 +1,1504 @@
+
+
+$(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)
+});
+
+
+
+
+
+
+
+
+
+