React Native 適配iPad

最近在用RN開發(fā)一款企業(yè)版的iPad版項目,在開發(fā)過程中不免會遇到適配的問題。比如長度的適配善绎,字體大小的適配。一般情況下诫尽,Flex布局能幫我們解決一些適配問題禀酱,但大多數情況下,需要我們自己去解決牧嫉。在此剂跟,我給大家介紹一下項目中是如何實現不同尺寸的iPad屏幕適配的。

首先酣藻,我們來看一組數據:

iPad設備(尺寸) ? ? ? ? ? ? ? ? ? ? ? ? 分辨率 ? ? ? ? ? ? ? ? ? ?點

iPad Pro(12.9 inch)? ? ? ? ? (2048x2732) ?(1024x1366) ? ? ? ? ? ? ? ? ? ?

iPad Pro(9.7 inch)? ? ? ? ? ? (1536x2048)? (768x1024)

iPad1/2(9.7 inch) ? ? ? ? ? ? ? (768x1024) ? ?(768x1024)

iPad3/4/air(9.7 inch) ? ? ? ? (1536x2048) ?(768x1024)

iPad mini(9.7 inch) ? ? ? ? ? ? (768x1024)? ? (768x1024)

iPad mini2(7.9 inch) ? ? ? ? (1536x2048) ? ? (768x1024)

? ? ? ? ? ? ? ? ?(斜粗字體為Retina屏曹洽,其他為普屏)

在開發(fā)過程中,我們不必糾結于屏幕的分辨率是多少辽剧,我們只要關注屏幕的點就行了送淆。蘋果為了方便開發(fā)人員開發(fā),在iOS中統一使用點(Point)對界面元素的大小進行描述怕轿。而點和像素的換算關系為:Retina屏 1點 = 2像素偷崩,普屏 1點 = 1像素

當我們仔細觀察上面的數據后發(fā)現撞羽,除了iPad Pro(12.9)的點為1024x1366阐斜,其他iPad設備的點都為768x1024。所以我們只需考慮這兩個點之間的比例關系就行了诀紊。屏寬比:1024 / 768 = ?1.333333333谒出, 屏高比:1366 / 1024 = 1.333984375, 經過計算我們發(fā)現兩者之間的比例關系非常接近 4 : 3 邻奠。這樣到推,我們在設置長度和字體的大小時,按著4:3的比例來進行就能很完美地適配了惕澎。

下面來加上部分RN代碼來具體說明一下:

// LengthStyles.js ?

import { Dimensions } from 'react-native'; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? const { width } = Dimensions.get('window'); ? ?

let LengthStyles = {}; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank1 = 3; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank2 = 6; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank15 = 45; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank20 = 60; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(width >1100){ ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank1 = 4; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank2 = 8; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank15 = 60; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? LengthStyles.lengthRank20 = 80; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }颜骤; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?export default LengthStyles;

// FontSizeStyles.js

import { Dimensions } from 'react-native'; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? const { width } = Dimensions.get('window');

let FontSizeStyles = {};? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank1 = 9;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank2 = 12;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank3 = 15;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank4 = 18;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(width >1100){? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank1 = 12;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank2 = 16唧喉;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank3 = 20;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? FontSizeStyles.lengthRank4 = 24;? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? };? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? export default FontSizeStyles;

這個兩個文件可以放在同一個文件夾styles下,然后建一個index.js來引一下:

import FontSizeStyles from './FontSizeStyles'; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? import LengthStyles from './LengthStyles';

export { ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?FontSizeStyles, ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?LengthStyles ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?}

以后調用的話八孝,直接 import {FontSizeStyles董朝,LengthStyles } from 'xx/../styles' 即可。

如標注圖尺寸是768x1024干跛,其中一個Text 的寬度為45 (width:45)子姜,我們在給這個 Text 的 width 賦值時就寫成 width:LengthStyles.lengthRank15。如果這個Text的字體大小為12 (fontSize: 12), 我們給這個Text的 fontSize 賦值時就寫成 fontSize:FontSizeStyles.lengthRank2楼入。根據 LengthStyles.js 和FontSizeStyles.js 代碼哥捕,在1024x1366的尺寸中,Text 的寬就會變成60嘉熊,字體大小就會變成16了遥赚,達到了適配效果。在實際開發(fā)中阐肤,如果遇到 LengthStyles.js 中沒有的長度凫佛,自己往里面添加就行,往FontSizeStyles.js 中添加新的字體大小也是一樣孕惜。

在適配的過程中愧薛,還需要注意一個地方,就是當標注的長度不為3的倍數怎么辦衫画?因為非3的倍數毫炉,你求得長度的 4/3 倍也就不為整數,如果UI要求比較高的話就四舍五入碧磅。如果UI要求還好的話碘箍,你就把非3倍數的長度加1或者減1來變成3的倍數,這樣計算起來就比較容易了鲸郊。

以上就是適配不同屏幕iPad的方法了丰榴。其實適配其他的尺寸,這個方法也是可以的秆撮。

很簡單的方法四濒,說起來只要幾分鐘,寫起來卻要幾個小時职辨,我要靜靜……

=====2017.8.1更新====

這里提供一種另一種方法:

import{ Dimensions } from 'react-native';

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

const basePx = 768 (多數iPad設備的點寬)

export default function pixelValue(px) {

return px * deviceW / basePx;

}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末盗蟆,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子舒裤,更是在濱河造成了極大的恐慌喳资,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腾供,死亡現場離奇詭異仆邓,居然都是意外死亡鲜滩,警方通過查閱死者的電腦和手機,發(fā)現死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進店門节值,熙熙樓的掌柜王于貴愁眉苦臉地迎上來徙硅,“玉大人,你說我怎么就攤上這事搞疗∩つⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵匿乃,是天一觀的道長桩皿。 經常有香客問我,道長扳埂,這世上最難降的妖魔是什么业簿? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮阳懂,結果婚禮上梅尤,老公的妹妹穿的比我還像新娘。我一直安慰自己岩调,他們只是感情好巷燥,可當我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著号枕,像睡著了一般缰揪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上葱淳,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天钝腺,我揣著相機與錄音,去河邊找鬼赞厕。 笑死艳狐,一個胖子當著我的面吹牛,可吹牛的內容都是我干的皿桑。 我是一名探鬼主播毫目,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼诲侮!你這毒婦竟也來了镀虐?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤沟绪,失蹤者是張志新(化名)和其女友劉穎刮便,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體绽慈,經...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡诺核,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年抄肖,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窖杀。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖裙士,靈堂內的尸體忽然破棺而出入客,到底是詐尸還是另有隱情,我是刑警寧澤腿椎,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布桌硫,位于F島的核電站,受9級特大地震影響啃炸,放射性物質發(fā)生泄漏铆隘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一南用、第九天 我趴在偏房一處隱蔽的房頂上張望膀钠。 院中可真熱鬧,春花似錦裹虫、人聲如沸肿嘲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雳窟。三九已至,卻和暖如春匣屡,著一層夾襖步出監(jiān)牢的瞬間封救,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工捣作, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留誉结,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓虾宇,卻偏偏與公主長得像搓彻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子嘱朽,可洞房花燭夜當晚...
    茶點故事閱讀 44,979評論 2 355

推薦閱讀更多精彩內容