做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

react native仿微信PopupWindow效果的實例代碼

來源:懂視網 責編:小采 時間:2020-11-27 22:33:14
文檔

react native仿微信PopupWindow效果的實例代碼

react native仿微信PopupWindow效果的實例代碼:在原生APP開發(fā)中,相信很多開發(fā)者都會見到這種場景:點擊右上角更多的選項,彈出一個更多界面供用戶選擇。這種控件在原生開發(fā)中Android可以用PopupWindow實現(xiàn),在iOS中可以用CMPopTipView,也可以自己寫一個View實現(xiàn)。其類似的效果如下圖所示: 實現(xiàn)思
推薦度:
導讀react native仿微信PopupWindow效果的實例代碼:在原生APP開發(fā)中,相信很多開發(fā)者都會見到這種場景:點擊右上角更多的選項,彈出一個更多界面供用戶選擇。這種控件在原生開發(fā)中Android可以用PopupWindow實現(xiàn),在iOS中可以用CMPopTipView,也可以自己寫一個View實現(xiàn)。其類似的效果如下圖所示: 實現(xiàn)思

在原生APP開發(fā)中,相信很多開發(fā)者都會見到這種場景:點擊右上角更多的選項,彈出一個更多界面供用戶選擇。這種控件在原生開發(fā)中Android可以用PopupWindow實現(xiàn),在iOS中可以用CMPopTipView,也可以自己寫一個View實現(xiàn)。其類似的效果如下圖所示:

實現(xiàn)思路分析:

要實現(xiàn)上面的視圖,有很多種實現(xiàn)方式。前面的文章說過,要實現(xiàn)彈框相關的可以用React Native 提供的 Modal組件(Modal組件),使用Modal組件可以實現(xiàn)我們原生開發(fā)中的大多數(shù)效果。

要實現(xiàn)下拉三角,可以讓美工切一個帶下拉三角的背景,當然也可以自己通過ART實現(xiàn)(ART繪制)。對于選項卡的內容,在原生開發(fā)中為了適應更多的場景,我們一般會選擇使用ListView組件,然后當點擊某個Item的時候獲得相應的屬性即可。為了控制Modal的顯示與消失,我們可以給Modal內置一個isVisible: this.props.show狀態(tài)。

源碼

要實現(xiàn)上面的效果,會這涉及到三個js文件:MorePopWidows.js、Utils.js、HomeActionBar.js,按照先后順序,代碼如下:

Utils.js

import {Dimensions} from 'react-native'

const deviceH = Dimensions.get('window').height
const deviceW = Dimensions.get('window').width

const basePx = 375

export default function px2dp(px) { 
 return px * deviceW / basePx
}

MorePopWidows.js

import React from 'react'
import {
 StyleSheet,
 Platform,
 View,
 Text,
 Image,
 TouchableOpacity,
 Alert,
 Modal,
 Dimensions,
} from 'react-native'
import SpacingView from "./SpacingView";
import QRScanPage from "../home/QRScanPage";

const { width, height } = Dimensions.get('window');
import px2dp from '../util/Utils'

const mTop = px2dp(Platform.OS == "ios" ? 64 : 44)

let mwidth = 95;
let mheight = 100;
const marginTop = mTop;

export default class MorePopWidows extends React.Component {

 constructor(props) {
 super(props);
 this.state = {
 isVisible: this.props.show,
 }
 mwidth = this.props.width ;
 mheight = this.props.height ;
 }

 componentWillReceiveProps(nextProps) {
 this.setState({ isVisible: nextProps.show });
 }

 closeModal() {
 this.setState({
 isVisible: false
 });
 this.props.closeModal(false);
 }

 scan() {
 this.props.navigator.push({
 component: QRScanPage,
 })
 }

 render() {
 return (
 <View style={styles.container}>
 <Modal
 transparent={true}
 visible={this.state.isVisible}
 animationType={'fade'}
 onRequestClose={() => this.closeModal()}>
 <TouchableOpacity style={styles.container} activeOpacity={1} onPress={() => this.closeModal()}>

 <View style={styles.modal}>
 <TouchableOpacity activeOpacity={1} onPress={this.scan.bind(this)} style={styles.itemView}>
 <Image style={styles.imgStyle} source={require('../images/ic_scan_code_white.png')} />
 <Text style={styles.textStyle}>掃一掃</Text>
 </TouchableOpacity>
 <SpacingView/>
 <TouchableOpacity activeOpacity={1} onPress={() => Alert.alert('點擊了付款碼')} style={styles.itemView}>
 <Image style={styles.imgStyle} source={require('../images/ic_code_white.png')} />
 <Text style={styles.textStyle}>付款碼</Text>
 </TouchableOpacity>
 </View>
 </TouchableOpacity>
 </Modal>
 </View>
 )
 }
}
const styles = StyleSheet.create({
 container: {
 width: width,
 height: height,
 },
 modal: {
 backgroundColor: '#696969',
 width: mwidth,
 height: mheight,
 position: 'absolute',
 left: width - mwidth - 10,
 top: marginTop,
 padding: 5,
 justifyContent: 'center',
 alignItems: 'center',
 borderRadius: 3,
 },
 itemView: {
 flexDirection: 'row',
 justifyContent: 'center',
 alignItems: 'center',
 flex: 1,
 },
 textStyle: {
 color: '#fff',
 fontSize: 14,
 marginLeft: 2,
 },
 imgStyle: {
 width: 20,
 height: 20,
 }
});

最后是在代碼中使用MorePopWidows的代碼:

HomeActionBar.js

/**
 * https://github.com/facebook/react-native
 * @flow 首頁的標題欄
 */

import React, {Component} from 'react';
import {Platform, View, Dimensions, Text, StyleSheet, TouchableOpacity, Image} from 'react-native';
import SelectCityPage from '../home/SelectCityPage'
import MorePopWidows from '../component/MorePopWidows'
import px2dp from '../util/Utils'

const isIOS = Platform.OS == "ios"
const {width, height} = Dimensions.get('window')
const headH = px2dp(isIOS ? 64 : 44)

export default class HomeActionBar extends Component {

 constructor(props) {
 super(props);
 this.state = {
 showPop: false,
 }
 }

 city() {
 this.props.navigator.push({
 component: SelectCityPage,
 })
 }

 renderHeader() {
 return (
 <View >
 <View style={styles.headerStyle}>
 <TouchableOpacity style={styles.action} onPress={this.city.bind(this)}>
 <Text style={styles.text}>上海</Text>
 <Image
 source={require('../images/ic_arrow_down.png')}/>
 </TouchableOpacity>
 <TouchableOpacity style={styles.searchBar}>
 <Image source={require('../images/ic_search.png')} style={styles.iconStyle}/>
 <Text style={{fontSize: 13, color: "#666", marginLeft: 5}}>輸入商家、商品名稱</Text>
 </TouchableOpacity>
 <TouchableOpacity style={styles.action} onPress={() => { this.setState({ showPop: !this.state.showPop }) }}>
 <Image style={styles.scanIcon}
 source={require('../images/ic_scan_code_white.png')}/>
 <Text style={styles.scanText}>掃碼</Text>
 </TouchableOpacity>
 </View>
 <View style={{ position: 'absolute', top: headH, left: 0, width: width, height: height }}>
 <MorePopWidows width={90} height={100} show={this.state.showPop} closeModal={(show) => {
 this.setState({showPop: show})
 }} {...this.props}/>
 </View>

 </View>
 )
 }

 render() {
 return (
 <View>
 {this.renderHeader()}
 </View>
 );
 }
}

const styles = StyleSheet.create({
 headerStyle: {
 backgroundColor: "#06C1AE",
 height: headH,
 paddingTop: px2dp(isIOS ? 20 : 0),
 paddingHorizontal: 16,
 flexDirection: 'row',
 alignItems: 'center',
 },
 searchBar: {
 width: width * 0.65,
 height: 30,
 borderRadius: 19,
 marginLeft: 10,
 flexDirection: 'row',
 justifyContent: 'flex-start',
 alignItems: 'center',
 backgroundColor: 'white',
 alignSelf: 'center',
 paddingLeft: 10,
 },
 text: {
 fontSize: 16,
 color: '#ffffff',
 justifyContent: 'center',
 },
 iconStyle: {
 width: 22,
 height: 22,
 },
 action: {
 flexDirection: 'row',
 justifyContent: 'center',
 alignItems: 'center',
 },
 scanIcon: {
 width: 28,
 height: 28,
 alignItems: 'center',
 marginLeft: 10,
 },
 scanText: {
 fontSize: 14,
 color: '#ffffff',
 justifyContent: 'center',
 alignItems: 'center',
 },
});

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

react native仿微信PopupWindow效果的實例代碼

react native仿微信PopupWindow效果的實例代碼:在原生APP開發(fā)中,相信很多開發(fā)者都會見到這種場景:點擊右上角更多的選項,彈出一個更多界面供用戶選擇。這種控件在原生開發(fā)中Android可以用PopupWindow實現(xiàn),在iOS中可以用CMPopTipView,也可以自己寫一個View實現(xiàn)。其類似的效果如下圖所示: 實現(xiàn)思
推薦度:
標簽: 微信 效果 實例
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 新河县| 周宁县| 拜泉县| 东莞市| 页游| 垫江县| 竹溪县| 曲周县| 蚌埠市| 张家界市| 凤台县| 平阳县| 尤溪县| 东兴市| 通道| 区。| 务川| 体育| 泽库县| 永济市| 怀柔区| 安平县| 抚宁县| 潼关县| 仁布县| 天峻县| 南溪县| 梁平县| 宁安市| 霍州市| 双柏县| 兴义市| 竹山县| 突泉县| 东兴市| 磴口县| 江油市| 洪江市| 新乡市| 金寨县| 昭苏县|