android banner阴影,仿照锤子科技官网的banner 3d效果

以前看到锤子科技官网的banner效果挺好玩的,一直没有研究;今天看到饥人谷,使用jquery给出了一种实现方式;我自己用原生js也实现了一遍。大致原理相同,但算法不同。

我的方法原理,如图所示,假设图中的小圆点是中心点;e的位置为事件发生的位置。在水平方向上,deltaX/centerX就是元素要旋转的度数代码在最下方。

bVGtEw?w=1499&h=827

//html

//css

.banner-wrap{

height: 900px;

outline: 1px dash #eee;

padding: 200px 0;

perspective: 1000px;

}

.banner{

width: 500px;

margin: 0 auto;

line-height: 500px;

box-sizing: border-box;

background-color: #37D7B2;

text-align: center;

line-height: 500px;

font-size: 50px;

color: #fff;

}

;(function(){

var bannerWrap = document.querySelector('.banner-wrap'),

banner = bannerWrap.querySelector('.banner');

banner.addEventListener('mousemove', function(e){

var centerX = banner.offsetLeft + banner.offsetWidth / 2,

centerY = banner.offsetTop + banner.offsetHeight / 2;

var deltaX = e.pageX - centerX,

deltaY = e.pageY - centerY;

var percentageX = deltaX / centerX,

percentageY = deltaY / centerY;

var deg = 10;

this.style.transform = 'rotateX(' + percentageY * -deg + 'deg)'

+ 'rotateY(' + percentageX * deg + 'deg)';

});

banner.addEventListener('mouseleave', function(e){

this.style.transform = '';

})

})();

  • 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、付费专栏及课程。

余额充值