banner实现

实现淘宝首页banner

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <meta name="viewport" content="width=device-width">
    <style media="screen">
    * {margin:0; padding:0; list-style:none;}
    html {font-size:10px}

    header {width:48rem;height:5.5rem;background:#fe5400; overflow:hidden; position:relative; z-index:99;}

    header h1 {width:4.4rem; height:3.7rem; background:url(img/logo.png) no-repeat; text-indent:-9999rem; background-size:100% 100%; margin-left:0.6rem; margin-top:1rem;}

    /*banner*/
    .banner {width:48rem; height:15rem; position:relative; overflow:hidden;}
    .banner ul {width:999rem; height:15rem; overflow:hidden; transform:translateX(-48rem);}
    .banner ul li {width:48rem; height:15rem; float:left;}
    .banner ul li img {width:100%; height:100%;}
    .banner ol {position: absolute; right:0; bottom: 1.3rem;}
    .banner ol li {width:1rem; height:1rem; border:1px solid #333; background:white; border-radius:50%; margin:0 0.4rem; opacity:0.6; float:left;}
    .banner ol li.active {background:#ff5501; border:1px solid #d0a793; opacity:1}

    /**/
    .page_content {background:white; position:relative; top:-5rem;}

    .load {height:5rem; line-height:5rem; text-align:center; font-size:2rem;}
    </style>
    <script>
    window.onresize=function (){
      document.documentElement.style.fontSize=document.documentElement.clientWidth/48+'px';
    };

    window.onresize();

    window.onload=function (){
      let oBanner=document.querySelector('.banner');
      let oBannerUl=oBanner.children[0];
      let oBannerUlLi=oBannerUl.children;
      let oPageContent=document.querySelector('.page_content');
      let oLoad=document.querySelector('.load');
      let aOlLi=document.querySelectorAll('.banner ol li');

      //
      oBannerUl.appendChild(oBannerUlLi[0].cloneNode(true));
      oBannerUl.insertBefore(oBannerUlLi[oBannerUlLi.length-2].cloneNode(true), oBannerUlLi[0]);

      let x=-oBannerUlLi[0].offsetWidth,y=0;

      oBanner.addEventListener('touchstart', function (ev){
        oPageContent.style.transition='none';
        oBannerUl.style.transition='none';//移除transition动画 提高性能

        let startX=ev.targetTouches[0].clientX;
        let startY=ev.targetTouches[0].clientY;

        let disX=startX-x;
        let disY=startY-y;

        let dir='';

        function fnMove(ev){//无法remove无名函数的event
          if(dir==''){
            if(Math.abs(ev.targetTouches[0].clientX-startX)>=5){
              dir='x';
            }else if(Math.abs(ev.targetTouches[0].clientY-startY)>=5){
              dir='y';
            }
          }else{
            if(dir=='x'){
              x=ev.targetTouches[0].clientX-disX;
            }else{
              y=ev.targetTouches[0].clientY-disY;
            }

            oBannerUl.style.transform=`translateX(${x}px)`;

            if(y>0){
              oPageContent.style.transform=`translateY(${y/3}px)`;//不跟随touch点

              if(y>200){
                oLoad.innerHTML='松手';
              }else{
                oLoad.innerHTML='下拉刷新';
              }
            }else{
              oPageContent.style.transform=`translateY(${y}px)`;
            }
          }
        }
        function fnEnd(){
          oBanner.removeEventListener('touchmove', fnMove, false);
          oBanner.removeEventListener('touchend', fnEnd, false);

          if(y>0){
            y=0;
            oPageContent.style.transition='0.3s all ease';
            oPageContent.style.transform=`translateY(0px)`;
          }

          //
          let n=Math.round(-x/oBannerUl.children[0].offsetWidth);
          x=-n*oBannerUl.children[0].offsetWidth;//判断谁是当前banner

          console.log(n);

          oBannerUl.style.transition='0.3s all ease';
          oBannerUl.style.transform=`translateX(${x}px)`;

          Array.from(aOlLi).forEach((li,index)=>{
            li.className=index==n?'active':'';
          })
        }

        oBanner.addEventListener('touchmove', fnMove, false);
        oBanner.addEventListener('touchend', fnEnd, false);
      }, false);
    };
    </script>
  </head>
  <body>
    <header>
      <h1>淘宝网</h1>
    </header>
    <div class="load">
      下拉刷新
    </div>
    <div class="page_content">
      <section class="banner">
        <ul>
          <li><img src="img/banner1.jpg" /></li>
          <li><img src="img/banner2.jpg" /></li>
          <li><img src="img/banner1.jpg" /></li>
          <li><img src="img/banner2.jpg" /></li>
          <li><img src="img/banner1.jpg" /></li>
          <li><img src="img/banner2.jpg" /></li>
        </ul>
        <ol>
          <li class="active"></li>
          <li></li>
          <li></li>
          <li></li>
          <li></li>
          <li></li>
        </ol>
      </section>
      <nav>

      </nav>
    </div>
  </body>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Android中实现阴影效果可以通过几种方式实现,以下是几种常用的方法: 1. 使用阴影的背景资源:可以在XML文件中创建一个带有阴影效果的背景资源,然后将其应用于Banner组件或其父布局,以达到阴影的效果。可以利用GradientDrawable和LayerDrawable等drawable类创建一个阴影资源,然后通过android:background属性将其应用于Banner组件。 2. 使用CardView:CardView是一种常用的用于创建阴影效果的布局容器,可以将Banner组件放置在CardView容器中,然后通过设置CardView的elevation属性和cardElevation属性来实现阴影效果。可以在XML布局文件中使用CardView包裹Banner组件,并设置相应的阴影属性,然后在Java代码中对Banner进行相关的设置。 3. 使用自定义阴影效果:可以通过绘制阴影效果的自定义Drawable实现阴影效果。可以自定义阴影效果的形状、颜色、大小等属性,并将其应用于Banner组件或其父布局。可以创建一个类继承自Drawable类,并在类的draw方法中实现具体的绘制阴影的逻辑。 总结来说,Android中实现Banner组件的阴影效果可以使用背景资源,CardView或自定义Drawable的方式来实现。具体使用哪种方法则取决于具体的需求和设计要求。 ### 回答2: 在Android中实现阴影效果可以使用以下几种方法: 1. 使用阴影背景图:可以创建一个包含阴影效果的背景图片,并将其设置为Banner的背景。这样可以在Banner的背景上显示出阴影效果。 2. 使用9patch图实现阴影:使用一个带有阴影效果的9patch图作为Banner的背景。9patch图是一种可以按需拉伸和平铺的图片,可以通过在特定区域绘制黑色像素,使其在Banner上显示为阴影效果。 3. 使用CardView控件:在Banner的父容器中使用CardView控件,并设置CardView的elevation属性来实现阴影效果。通过设置不同大小的elevation值,可以调整阴影的大小和深度。 4. 使用自定义绘制:可以通过在Banner的onDraw方法中使用Canvas绘制阴影效果。可以使用Paint设置阴影颜色、大小和透明度,并在绘制Banner时应用阴影效果。 以上是实现阴影效果的几种常用方法,根据具体需求选择最适合的方式。在选择方法时,可以考虑到性能、可定制性和兼容性等因素。 ### 回答3: 要在Android中实现阴影效果,可以通过以下步骤: 1. 首先,在XML布局文件中定义一个Banner组件。例如:<android.support.v7.widget.AppCompatImageView android:id="@+id/banner" android:layout_width="match_parent" android:layout_height="wrap_content" /> 2. 在Java代码中找到Banner组件,并为其设置阴影效果。例如,在Activity的onCreate方法中添加以下代码: AppCompatImageView banner = findViewById(R.id.banner); banner.setBackgroundResource(R.drawable.banner_shadow); 3. 创建banner_shadow.xml文件,用来实现阴影效果。在res/drawable文件夹下创建banner_shadow.xml,并添加以下代码: <shape xmlns:android="http://schemas.android.com/apk/res/android"> <solid android:color="#FFFFFF"/> <corners android:radius="5dp" /> <padding android:left="1dp" android:top="1dp" android:right="1dp" android:bottom="1dp" /> <gradient android:startColor="#55000000" android:endColor="#00000000" android:angle="270" /> </shape> 其中,solid定义了背景色,corners定义了圆角效果,padding定义了内边距,gradient定义了渐变色效果。 4. 最后,运行应用程序,你会看到Banner显示出一个带有阴影的效果。 这是一种简单的方法来实现在Android中的Banner组件添加阴影效果。你也可以根据自己的需求进行调整,并尝试不同的阴影效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值