React Native之在Android上添加阴影的实现

 更新时间:2023年03月12日 15:09:15   作者:spicyboiledfish  
这篇文章主要介绍了React Native之在Android上添加阴影的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

在Android上添加阴影

官网中明确表示在react native中阴影的样式属性shadow...都是只支持iOS的,并不支持Android。

目前有个方法

可以让Android有灰色的阴影,但是无法指定Android机上的阴影色值,只能是灰色的默认。

elevation:4   这个属性中的4是代表阴影的高度。

且这个属性添加后,不会影响iOS机上的原本的彩色的阴影颜色,只是在Android机上显示的是默认的灰色的阴影。

btnView:{
        width:170,
        alignItems:'center',
        borderRadius:20,
        height:35,
        justifyContent:'center',
        backgroundColor: Color.CMHeaderBgColor,
        
        //以下是阴影属性:
        shadowOffset: {width: 0, height: 5},
        shadowOpacity: 0.5,
        shadowRadius: 5,
        shadowColor: Color.CMHeaderBgColor,
        //注意:这一句是可以让安卓拥有灰色阴影
        //elevation: 4,
        zIndex: Global.isIOS() ? 1 : 0
}

补充:有两种方式,解决安卓可以实现彩色阴影的问题:

方法一:使用react-native-shadow和react-native-svg实现:

1. npm install react-native-shadow

2. npm install react-native-svg@5.1.8

备注:react-native-svg选择什么版本安装,需要根据你项目的react版本和react-native版本;图解如下:

3. react-native link react-native-svg

4.开始写样式,适合安卓和iOS的阴影,支持透明度,长度,色值的配置:

import React, {Component} from 'react'
import {
    StyleSheet,
    View,
    Text,
    ScrollView,
    Image,
    TouchableOpacity
} from 'react-native'
 
import {BoxShadow} from 'react-native-shadow'
 
export default class VideoCell extends Component {
    render = () => {
        const shadowOpt = {
            width:160,
            height:170,
            color:"#000",
            border:2,
            radius:3,
            opacity:0.2,
            x:0,
            y:3,
            style:{marginVertical:5}
        }
 
        return (
            <BoxShadow setting={shadowOpt}>
                <TouchableOpacity style={{
                    position:"relative",
                    width: 160,
                    height: 170,
                    backgroundColor: "#fff",
                    borderRadius:3,
                    // marginVertical:5,
                    overflow:"hidden"}}>
                    测试
                </TouchableOpacity>
            </BoxShadow>
        )
    }
}

事实证明这种方法可以实现我们想要的效果。但是这会牵扯到你的项目不能仅仅通过热更新来迭代版本;需要发app store大版本和安卓市场版本。

如有不解,可移步查看react-native-shadow官网:

https://www.npmjs.com/package/react-native-shadow

方法二:

我们可以使用阴影图作为背景图,附着上去的方法:

<Image source={require('../../content/img/bank/shadowBg.png')}
   style={{width: deviceWidth-20, height: 220, alignItems: 'center',resizeMode:Image.resizeMode.contain}}> 
  <View style={styles.bankTop}></View>           
</Image>

Image组件,当为单标签是图片;当未双标签是背景;

如图:可以看到有屎黄色☺的背景:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Android编程自定义菜单实现方法详解

    Android编程自定义菜单实现方法详解

    这篇文章主要介绍了Android编程自定义菜单实现方法,结合实例形式分析了Android自定义菜单的布局、动画及功能相关实现技巧与注意事项,需要的朋友可以参考下
    2017-02-02
  • Android自动化测试处理各种弹窗的操作方法

    Android自动化测试处理各种弹窗的操作方法

    这篇文章主要介绍了Android自动化测试中如何处理各种弹窗,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2021-07-07
  • camera录制视频的缩略图获取原理心得分享

    camera录制视频的缩略图获取原理心得分享

    camera录制的视频的缩略图如何获取,想必有很多的朋友都不会吧,下面与大家分享下获取的原理,感兴趣的你可不要错过了哈
    2013-06-06
  • Android 多线程处理之多线程详解

    Android 多线程处理之多线程详解

    本文主要介绍Android 多线程处理的知识资料,这里整理下来详细的知识,和简单代码实现和实现效果图,有需要的朋友可以参考下
    2016-09-09
  • Android使用OKHttp库实现视频文件的上传到服务器功能

    Android使用OKHttp库实现视频文件的上传到服务器功能

    这篇文章主要介绍了Android使用OKHttp库实现视频文件的上传到服务器功能,需要的朋友可以参考下
    2018-03-03
  • Android中activity处理返回结果的实现方式

    Android中activity处理返回结果的实现方式

    这篇文章主要介绍了Android中activity处理返回结果的实现方式,为了实现这个功能,Android提供了一个机制,跳转到其他activity时,再返回,可以接受到其他activity返回的值,无需再start新的当前activity。需要的朋友可以参考下
    2016-12-12
  • Flutter Widget之NavigationBar使用详解

    Flutter Widget之NavigationBar使用详解

    这篇文章主要为大家介绍了Flutter Widget之NavigationBar使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 在ubuntu下编译ijkplayer-android的方法

    在ubuntu下编译ijkplayer-android的方法

    下面小编就为大家分享一篇在ubuntu下编译ijkplayer-android的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Android LinearLayout实现自动换行

    Android LinearLayout实现自动换行

    这篇文章主要为大家详细介绍了Android LinearLayout实现自动换行,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Android开发Jetpack组件ViewModel使用讲解

    Android开发Jetpack组件ViewModel使用讲解

    这篇文章主要介绍了Android Jetpack架构组件 ViewModel详解,ViewModel类让数据可在发生屏幕旋转等配置更改后继续存在,ViewModel类旨在以注重生命周期的方式存储和管理界面相关的数据,感兴趣可以来学习一下
    2022-08-08

最新评论