React Native (android), компоненты перекрываются с проблемой теней - PullRequest
0 голосов
/ 29 октября 2018

Я использую пользовательский компонент с изображением и текстом. Изображение относительно текста. Пожалуйста, смотрите скриншот. изображение 1
изображение 2 .

Я использовал компонент TouchableOpacity в качестве корневого представления для этого.

На скриншотах при длительном нажатии на компонент два вида перекрываются с тенью. Это выглядит некрасиво, когда долго жмешь.

Пожалуйста, смотрите код ниже для многоразового использования компонента.

'use strict';

import React, {Component} from 'react';
import {
  StyleSheet,
  Text,
  View,
  TouchableOpacity,
  Image,
} from 'react-native';

export default class ExampleButton extends Component {

  constructor (props) {
    super (props);
  }
  _handleOnPress = () => {
    console.log('pressed!!!');
  };

  render () {
    console.log (this.props);
    return (
      <TouchableOpacity
        onPress={this.handleOnPress}
      >
        <View style={styles.btnCompContainer}>
          <View
            style={{
              backgroundColor: '#FFF',
              justifyContent: 'center',
              borderRadius: 30,
              height: 50,
              width: '100%',
            }}
          >
            <Text style={styles.btnTxt}>{this.props.buttonText}</Text>
          </View>

          <View style={[styles.btnElmContainer]}>
            <Image
              style={[{height: 30, width: 30,resizeMode:'stretch'}]}
              source={this.props.image}
            />
          </View>
        </View>

      </TouchableOpacity>
    );
  }
}

const styles = StyleSheet.create ({
  btnCompContainer: {
    flexDirection: 'row',
    alignItems: 'center',
    height: 60,
    marginLeft: 10,
    marginRight: 20,
  },
  btnElmContainer: {
    position: 'absolute',
    justifyContent: 'center',
    alignItems: 'center',
    width: 60,
    height: 60,
    backgroundColor:'#fff',
    borderRadius: 30,
    shadowColor: '#000000',
    shadowOffset: {
      width: 1,
      height: 1,
    },
    elevation:5,
    shadowRadius: 2,
    shadowOpacity: 0.3,
  },
  btnTxt: {
    marginLeft: 80,
    color: '#9e9e9e',
    fontSize: 16,
    fontWeight: 'bold',
    textAlign: 'left',
  },
});

Здесь я использую этот повторно используемый компонент в коде.

    'use strict';

import React, {Component} from 'react';
import {
  Animated,
  StyleSheet, 
  Text,
  TextInput,
  View, 
  Image,
  ImageBackground,
  TouchableOpacity,
  Button,
  StatusBar,
  Easing
} from 'react-native';

//  Custom Components

const searchBGImg = require('../assets/search-bg-kit.png');
const houseLogo = require('../Resources/house.png');

import ExampleButton from './components/common/example-button';


export default class TypeSelect extends Component<Props> {
  //  Navigation Option
  static navigationOptions = {
    header: null
  }
  constructor() {
    super();  
    this.state = {
      visible: false,
      x: new Animated.Value(-100),
    };
  }
  slide = () => {
    Animated.spring(this.state.x, {
      toValue: 0,
      easing: Easing.easeOutBack
    }).start();
    this.setState({
      visible: true,
    });
  };
  gotoSearch = () =>{
    this.props.navigation.navigate('DocSearch')
  }
  componentDidMount(){
    this.slide();
  }
  render() {

    return (
      <View style={styles.container}>
        <ImageBackground source={searchBGImg} style={styles.imgBG}>
          <View style={{alignItems:'center', marginBottom:20}}> 
            <Image style={{height:57, width:69, marginBottom:12}} source={houseLogo} />
          </View>
          <View>
            <Animated.View
              style={[styles.slideView, {
                transform: [
                  {
                    translateX: this.state.x
                  }
                ]
              }]}>

              <ExampleButton image={houseLogo} buttonText={'Click here'} />
              <ExampleButton image={houseLogo} buttonText={'Click here'} />

            </Animated.View>  
          </View>
        </ImageBackground>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1
  },
  imgBG:{
    flex: 1,
    flexDirection: "column",
    justifyContent:"center",
    width: "100%", 
    height: "100%"
  }
})

В iOS работает нормально, но в андроиде не работает на должном уровне. Пожалуйста, помогите мне работать в Android. Заранее спасибо.

...