Expo大作戰(三十)--expo sdk api之Permissions(許可權管理模塊),Pedometer(計步器api)

来源:https://www.cnblogs.com/gdsblog/archive/2018/03/19/8601333.html
-Advertisement-
Play Games

簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...


簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網

我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732981

【之前我寫過一些列關於expo和rn入門配置的東i西,大家可以點擊這裡查看:從零學習rn開發

相關文章:

Expo大作戰(一)--什麼是expo,如何安裝expo clinet和xde,xde如何使用

Expo大作戰(二)--expo的生命周期,expo社區交流方式,expo學習必備資源,開發使用expo時關註的一些問題

Expo大作戰(三)--針對已經開發過react native項目開發人員有針對性的介紹了expo,expo的局限性,開發時項目選型註意點等

Expo大作戰(四)--快速用expo構建一個app,expo中的關鍵術語

Expo大作戰(五)--expo中app.json 文件的配置信息

Expo大作戰(六)--expo開發模式,expo中exp命令行工具,expo中如何查看日誌log,expo中的調試方式

Expo大作戰(七)--expo如何使用Genymotion模擬器

Expo大作戰(八)--expo中的publish以及expo中的link,對link這塊東西沒有詳細看,大家可以來和我交流

更多>>

寫在二十三章以後的話,之前的翻譯,不管如何,好與不好,終究是告一段落,也把expo基礎理論的東西又深入的理解了一遍,後續expo大作戰系列將主要介紹expo sdk的api。


許可權(Permissions)

當添加可訪問用戶設備上潛在敏感信息的功能(例如其位置)時,或可能向其發送可能不需要的推送通知時,您需要首先詢問用戶的許可。 除非你已經征求他們的許可,否則不需要(Unless you’ve already asked their permission, then no need)。 所以我們有許可權模塊。

如果您正在將應用程式部署到Apple iTunes Store,則應考慮嚮應用程式添加其他元數據,以便自定義系統許可權對話框並解釋您的應用程式需要許可權的原因。 請參閱App Store部署指南中的更多信息。

Expo.Permissions.getAsync(type)

確定您的應用是否已被授予對提供的許可權類型的訪問許可權。

參數

type(string) - 許可權的名稱。

返回

返回使用關於許可權的信息解決的Promise,包括狀態,到期和範圍(如果它適用於許可權類型)。(Returns a Promise that is resolved with the information about the permission, including status, expiration and scope (if it applies to the permission type).)

async function alertIfRemoteNotificationsDisabledAsync() {
  const { Permissions } = Expo;
  const { status } = await Permissions.getAsync(Permissions.NOTIFICATIONS);
  if (status !== 'granted') {
    alert('Hey! You might want to enable notifications for my app, they are good.');
  }
}

 

Expo.Permissions.askAsync(type)

提示用戶獲得許可。 如果他們已經授予訪問許可權,則回應將成功。

參數

type(string) - 許可權的名稱。

返回

返回使用關於許可權的信息解決的Promise,包括狀態,到期和範圍(如果它適用於許可權類型)。

async function getLocationAsync() {
  const { Location, Permissions } = Expo;
  const { status } = await Permissions.askAsync(Permissions.LOCATION);
  if (status === 'granted') {
    return Location.getCurrentPositionAsync({enableHighAccuracy: true});
  } else {
    throw new Error('Location permission not granted');
  }
}

Expo.Permissions.NOTIFICATIONS

本地和推送通知的許可權類型。

註意:在iOS上,這不會消除未確定 拒絕,因此只會返回已授予或未確定。 這是由於底層本機API的實現方式所致。

Expo.Permissions.LOCATION
位置訪問許可權類型。

Expo.Permissions.CAMERA
照片和視頻拍攝的許可類型。

Expo.Permissions.AUDIO_RECORDING
音頻錄製的許可類型。

Expo.Permissions.CONTACTS
閱讀聯繫人的許可權類型。

Expo.Permissions.CAMERA_ROLL
用於讀取或寫入相機的許可類型。

 

計步器(Pedometer)

使用Core Motion(iOS)或Google Fit(Android)獲取用戶的步數。

Expo.Pedometer.isAvailableAsync()


確定計步器是否可用。

返回

返回一個可解析為布爾值的承諾,指示計步器是否在此設備上可用。

 

Expo.Pedometer.getStepCountAsync(start, end)

獲取兩個日期之間的步數。

參數

start(datetime) - 指示測量步驟的範圍開始的日期。
end(end) - 指示測量步驟的範圍結束的日期。


返回

返回一個使用steps鍵解析為Object的promise,它是一個Number,表示在給定日期之間所採用的步數。


Expo.Pedometer.watchStepCount(callback)


訂閱計步器更新。

參數

回調函數(callback)當新的步數數據可用時調用的回調函數。 該回調提供了一個單個參數,該參數是具有步驟鍵的對象。


返回

一個EventSubscription對象,當您想要取消訂閱偵聽器時,您可以調用remove()。

 


下一張繼續介紹,這一篇主要介紹了:expo sdk api之Permissions(許可權管理模塊),Pedometer(計步器api),歡迎大家關註我的微信公眾號,這篇文章是否被大家認可,我的衡量標準就是公眾號粉絲增長人數。歡迎大家轉載,但必須保留本人博客鏈接!

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前幾天編寫一個存儲過程,需要訪問遠程資料庫的欄位,於是建立一個dbLink並建了同義詞: 這裡之所以用orcl@bdc為dblink的名稱是為了設置global_names=true。 然後新建一個存儲過程調用該同義詞: v_result mtb.sid%type; 調用後發現提示:錯誤:PLS-0 ...
  • 主從伺服器 1. 將讀操作和寫操作分離到不同的資料庫上,避免主伺服器出現性能瓶頸; 2. 主伺服器進行寫操作時,不影響查詢應用伺服器的查詢性能,降低阻塞,提高併發; 3. 數據擁有多個容災副本,提高數據安全性,同時當主伺服器故障時,可立即切換到其他伺服器,提高系統可用性; 讀寫分離的基本原理就是讓主 ...
  • -(void)didReceiveMemoryWarning{ [super didReceiveMemoryWarning]; } 在這裡你需要釋放掉所有占用了很大記憶體的對象,如果你忽略了這個警告,應用有可能直接閃退。iOS設備沒有虛擬記憶體或者交換分區,記憶體用完了就是真的用完了,沒有任何迴旋的餘地 ...
  • 簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...
  • 簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...
  • Android #Android開發環境搭建 1.下載:Google在國服的官網 https://developer.android.google.cn/index.html 1.點擊首頁 “ 獲取 Android Studio” 2.跳轉以後等待網頁載入完(左上角顯示X則是未載入完)再點擊綠色的“ ...
  • ##init腳本的啟動 linux內核載入完成後,運行init.rc腳本 /system/bin/app_process Zygote服務啟動的進程名 --start-system-server 表明Zygote啟動完成之後,要啟動System進程。 socket zygote stream 666 ...
  • SnackBar是 Android Support Library 22.2.1 裡面新增提供的一個控制項,我們可以簡單的把它理解成一個加強版的Toast,或者是一個輕量級的Dialog。 特點: 看一下SnackBar的使用方法: 三個參數:View ,內容文本,顯示時長 和Toast的使用類似 T ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...