Slide 1

Slide 1 text

͋ͷ਒͑ΔΠϯλϥΫγϣϯΛ࣮૷͍ͨ͠ 2019-07-03 React LTձ twitter: @nitaking_ github: nitaking

Slide 2

Slide 2 text

About ɾSatoshi Nitawaki ɾ೔ຊञ޷͖ΤϯδχΞ ɾReact Native, Node, TSͳͲ ɾ࠷ۙ͸OSS࡞ͬͯΈͨΓ

Slide 3

Slide 3 text

No content

Slide 4

Slide 4 text

෼͕มߋ͞ΕΔͨͼʹ খ͞ͳόΠϒ͕ൃੜ͢Δ ʢiOSͩͱTwitter͍͍ͶϘλϯԡͨ͠ͱ͖ͷ਒͑Ͱ͢ʣ

Slide 5

Slide 5 text

͜Εͳʹʁ

Slide 6

Slide 6 text

Haptic (Haptic Feedback) - ৮֮ϑΟʔυόοΫ

Slide 7

Slide 7 text

Haptic (Haptic Feedback) iOS 10(iPhone7)͔ΒOSʹAPI૷උ iPhone͸೔ৗతʹϙίϙί → iPhone 7 - 8ͷϗʔϜϘλϯ΋Hapticѻ͍͔ͳ Android͸ͨ·ʹ͔͠ϙίϙίಈ͔ͳ͍ → AndroidϢʔβʔʹ͸ׂͱ৽઱

Slide 8

Slide 8 text

Haptic (Haptic Feedback) ex) ɾtogglͷೖྗ࣌ؒมߋ ɾinstagramͷετʔϦʔ ϑΟϧλʔมߋ ɾϦετը໘ͷεϫΠϓμ΢ϯͯ͠ߋ৽ͨ͠ͱ͖ʢiosʣ ɾRNͷRefreshControlͷonRefresh࣌ʹios͸਒͑ͯͨ͸ͣ ɾappstoreͷΠϯετʔϧ׬ྃɺࣦഊʢiosʣ ɹɾجຊతʹiOSͷΤίγεςϜ಺͸਒͑·ͬͯ͘ΔΠϝʔδ

Slide 9

Slide 9 text

React NativeͰ࣮૷ͯ͠Έ͍ͨ

Slide 10

Slide 10 text

࣮૷ 1. RNͷඪ४Vibration • όΠϒ࣌ؒ୹ͨ͘͠Βߦ͚Δ͔ͱࢥͬͨΒͦΜͳ͜ͱ ͸ͳ͍ • ਺msecηοτˠʮϒʔʔϯʯ • ͜Ε͸ઈର͕ͪ͏

Slide 11

Slide 11 text

࣮૷ 2. expo-haptic • ໊લ͔Βͯ͠ຊ໋ • Expo APIͷͻͱͭ • ΋ͪΖΜexpoΞϓϦ͔Β͸͙͢ʹ࢖༻Ͱ͖Δ • ଞʹHapticܥϥΠϒϥϦ͸ଘࡏ͠ͳ͔ͬͨ

Slide 12

Slide 12 text

࣮૷ 2. expo-haptic • Haptic.selectionAsync() • Haptic.notificationAsync(NotificationFeedback) • success • warning • error • Haptic.impactAsync(ImpactFeedback) • light • medium • heavy • Asyncදهͷͳ͍method΋͋Γ·͕͢DeprecatedͰ͢

Slide 13

Slide 13 text

ૉͷRNͰ࢖͑ΔΜ͚ͩͬʁ

Slide 14

Slide 14 text

react-native-unimodules

Slide 15

Slide 15 text

react-native-unimodules • expo APIΛૉͷRNͰ΋࢖༻Մೳʹ͢Δ؀ڥΛఏڙ • ಋೖͷྲྀΕ 1. npm install react-native-unimodules 2. ΞϓϦͷ֤ػೳ΁ͷPermissionઃఆ
 
 ɾɾɾunimoduleΛinstallͯ͠࢖͏

Slide 16

Slide 16 text

ಋೖ • https://github.com/unimodules/react-native-unimodules • Android • android/settings.gradle มߋ • android/app/build.gradle มߋ • minSdkVersion ɿ16 → 21 • MainApplication.java มߋ • AndroidManifest.xml ʹ
 permission௥Ճ • ਌੾ʹDiff΋༻ҙ͞ΕͯΔͷͰ
 ಋೖ͸Θ͔Γ΍͍͢

Slide 17

Slide 17 text

ಋೖ • https://github.com/unimodules/react-native-unimodules • iOS • Podfile มߋ • AppDelegate.h มߋ • AppDelegate.m มߋ • Info.plist ʹpermission௥Ճ

Slide 18

Slide 18 text

react-native-unimodules • react-native-unimodulesͷpod install࣌ • ↓defaultͰ20ݸۙ͘unimodule͕install͞ΕͪΌ͏
 ΞϓϦαΠζΛҙࣝ͢ΔͳΒݸผʹignoreࢦఆΛͨ͠΄͏͕͍͍ɻʢެࣜࢀরʣ

Slide 19

Slide 19 text

Expo-haptics • ૉͷRNʹexpo-hapticsೖΕͯΈͨ • Ի੠͕ͳ͍ͱ·ͬͨ͘఻ΘΒͳ͍ͷͰɹ
 ޙ΄ͲπΠολʔʹΞοϓ͠·͢ʂ

Slide 20

Slide 20 text

ଞͷunimoduleͬͯͲΜͳͷ͕͋Δʁ

Slide 21

Slide 21 text

unimodules • expo-ads-admob • expo-ads-facebook • expo-analytics-amplitude • expo-analytics-segment • expo-app-auth • expo-app-loader-provider • expo-asset • expo-av • expo-background-fetch • expo-barcode-scanner • expo-blur • expo-brightness • expo-calendar • expo-camera • expo-constants • expo-contacts-flutter-plugin • expo-contacts • expo-crypto • expo-document-picker • expo-face-detector • expo-facebook • expo-file-system • expo-flutter-adapter • expo-font • expo-gl-cpp • expo-gl • expo-google-sign-in • expo-haptics • expo-image-manipulator • expo-image-picker • expo-in-app-purchases • expo-intent-launcher • expo-keep-awake • expo-linear-gradient • expo-local-authentication • expo-localization • expo-location • expo-mail-composer • expo-media-library • expo-module-scripts • expo-module-template • expo-payments-stripe • expo-permissions-flutter-plugin • expo-permissions • expo-print • expo-processing • expo-random • expo-secure-store • expo-sensors-flutter-plugin • …ʴ10ݸ͘Β͍ https://docs.expo.io/versions/latest/bare/unimodules-full-list/

Slide 22

Slide 22 text

Expo APIs • expo-ads-admob • expo-ads-facebook • expo-analytics-amplitude • expo-analytics-segment • expo-app-auth • expo-app-loader-provider • expo-asset • expo-av • expo-background-fetch • expo-barcode-scanner • expo-blur • expo-brightness • expo-calendar • expo-camera • expo-constants • expo-contacts-flutter-plugin • expo-contacts • expo-crypto • expo-document-picker • expo-face-detector • expo-facebook • expo-file-system • expo-flutter-adapter • expo-font • expo-gl-cpp • expo-gl • expo-google-sign-in • expo-haptics • expo-image-manipulator • expo-image-picker • expo-in-app-purchases • expo-intent-launcher • expo-keep-awake • expo-linear-gradient • expo-local-authentication • expo-localization • expo-location • expo-mail-composer • expo-media-library • expo-module-scripts • expo-module-template • expo-payments-stripe • expo-permissions-flutter-plugin • expo-permissions • expo-print • expo-processing • expo-random • expo-secure-store • expo-sensors-flutter-plugin • …ʴ10ݸ͘Β͍ ଟ͗͢ Flutter pluginͱ͔͋Δ ༏लͳunimodule͋Δ

Slide 23

Slide 23 text

• expo-face-detector • إೝࣝ • Ṗਫ਼౓ • ඍসΈ཰ͱΕΔ • ໨Λ։͍͍ͯΔ཰΋ • ਖ਼໘OK,ԣ޲͖ࣸਅNG
 ͷόϦσʔγϣϯ
 ʹ࢖͑Δʁ ྫ͑͹

Slide 24

Slide 24 text

expo͸ૉRNʹ ؔ܎ͷͳ͍࿩ͩͱࢥ͍ͬͯͨ

Slide 25

Slide 25 text

expoͷ༏लͳunimodules͸ ࣮͸ૉͷRNͰ΋࢖͑Δ

Slide 26

Slide 26 text

Enjoy RN dev!