Android10.0(Q)新特性和行爲變更

Android Q 還爲開發者們帶去了許多新功能,如摺疊屏增強項、新網絡連接 API、全新的媒體解碼器、攝像頭新功能、NNAPI 擴展、Vulkan 1.1 圖形支持等等。2019/4 Beta2版本發佈(點擊查看Google官文),5月份將會正式發佈。

Android Q 隱私更改相關介紹

1,存儲範圍變更

Android Q 改變了應用程序訪問設備外部存儲上文件的方式。 通過使用更細粒度的媒體特定權限替換以前的 READ_EXTERNAL_STORAGE 和 WRITE_EXTERNAL_STORAGE權限。

2,外存中私有目錄權限變更

Android Q 爲每個應用程序提供了一個獨立的在外部存儲設備的存儲沙箱,沒有其他應用可以直接訪問您應用的沙盒文件。由於文件是私有的,因此訪問這些文件不再需要任何權限。

並且 Android Q 推薦了獲取外部存儲私有文件的最佳位置:即Context.getExternalFilesDir()返回的位置,因爲此位置在所有Android版本中表現一致。使用此方法時,請傳入與要創建或打開的文件類型對應的媒體環境。例如,要訪問或保存app-private圖像,請調用Context.getExternalFilesDir(Environment.DIRECTORY_PICTURES)。

3,公共媒體集合特性

  1. 定義公共媒體集合:Photos & Videos、Music、 Downloads。

  2. APP 無需請求任何權限即可在這些共享集合中創建和修改自己的文件。

  3. 如果你的APP想創建和修改其他應用已創建的文件,則必須首先請求相應的權限:

訪問Photos & Videos目錄的其他應用程序文件 需要請求 READ_MEDIA_IMAGES 或 READ_MEDIA_VIDEO 權限,具體取決於您的應用程序需要訪問的文件類型。

訪問 Music 共享集合中的其他應用程序文件需要 READ_MEDIA_AUDIO 權限。

沒有訪問Downloads共享集合的權限,您的應用可以訪問此集合中自己的文件。但是,要訪問此集合中的其他應用程序文件,您必須允許用戶使用系統的文件選擇器應用程序選擇文件。

4,訪問共享集合

訪問共享集合通過 MediaStore API ,如 MediaStore.Images、MediaStore.Video、MediaStore.Audio、MediaStore.Downloads。
需要注意的是:對於 Android Q 上新安裝的應用,對 getExternalStoragePublicDirectory()的調用僅提供對應用已存儲在其隔離存儲沙箱中的文件的訪問權限。要保持對其他應用程序文件的訪問權限,請更新應用程序的邏輯以使用MediaStore。

5,新增 ACCESS_MEDIA_LOCATION 權限

一些照片在其數據中會包含位置信息,允許用戶查看拍攝照片的位置。由於此位置信息是敏感的,因此我們想獲取位置信息需要以下幾步:

        1.將新的 ACCESS_MEDIA_LOCATION 權限添加到AndroidManifest。
        ​​​​​​​2.獲取位置信息

photoUri = MediaStore.setRequireOriginal(photoUri);
InputStream stream = getContentResolver().openInputStream(photoUri);
//從流中讀取位置信息

6,存儲新特性兼容

target API 級別等於 Android Q 的應用,或者在運行Android Q 的設備上新安裝的應用默認都會採取新的權限策略
如果你的APP同時滿足以下兩個條件,則會兼容以前的權限策略:

  1. targetSdkVersion <= Android 9

  2. 你的應用安裝在從 Android 9 升級到 Android Q 的設備上

識別特定的外部存儲設備
Android Q 爲每個外部存儲設備提供唯一的卷名。

 //獲取卷名方式
Set<String> volumeNames = MediaStore.getAllVolumeNames(context);

7,Activity後臺活動限制

Android Q 對應用未經通知用戶就啓動進行了極大地限制,在Android Q上運行的應用只有在滿足以下一個或多個條件時才能啓動活動:

  1. 該APP具有可見窗口,例如有前臺Activity

  2. 位於前臺的另一個 APP 發送屬於該應用程序的 PendingIntent。

  3. 系統發送屬於該 APP 的PendingIntent,例如點擊通知。

  4. 系統嚮應用程序發送廣播,例如SECRET_CODE_ACTION。只有應用程序預期啓動UI的特定廣播才免除。

8.活動限制的兼容性

此行爲更改適用於在 Android Q 上運行的所有應用,甚至是針對Android 9(API級別28)或更低級別的應用。但是,只要您的應用以用戶互動的直接結果開始活動,您的應用很可能不會受到此更改的影響。實際上,大多數應用程序都不受此更改的影響。

此外,Android Q 建議我們 後臺應用程序都應創建通知,以便向用戶提供信息,而不是直接啓動活動。

一些特殊情況如:來電或者警報,需要立刻啓動 Activity,則可以通過創建高優先級的通知,並提供 fullscreen itent。如何創建高優先級通知?

9.設備位置權限的訪問控制

用戶可以更好地控制應用何時可以訪問設備位置。當在Android Q上運行的應用程序請求位置訪問時,會通過對話框的形式給用戶進行授權提示。此對話框允許用戶授予對兩個不同範圍的位置訪問權限:在使用中(僅限前臺)或始終(前臺和後臺)。

新增權限 ACCESS_BACKGROUND_LOCATION

如果你的應用針對 Android Q 並且需要在後臺運行時訪問用戶的位置,則必須在應用的清單文件中聲明新權限

<manifest>
  <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
  <uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />
</manifest>

10.位置限制的兼容性

如果您的應用在 Android Q 上運行但針對的是 Android 9(API級別28)或更低版本,則會出現以下行爲:

  1. 如果你的應用爲 ACCESS_FINE_LOCATION 或 ACCESS_COARSE_LOCATION 聲明  標記,則系統會在安裝期間自動爲ACCESS_BACKGROUND_LOCATION 添加  標記。

  2. 如果你的應用請求 ACCESS_FINE_LOCATION 或 ACCESS_COARSE_LOCATION,系統會自動將 ACCESS_BACKGROUND_LOCATION添加到請求中。

  3. 雖然你的應用可以請求並接收 ACCESS_BACKGROUND_LOCATION,但用戶可以通過選擇您的應用僅應在前臺訪問位置信息來撤消此權限。

11,允許應用程序降級。

當對商店更新後的版本後悔時,可以“回到過去”即回滾到舊版。
 

12.對數據和標識符的更改

影響在Android Q 上運行的所有應用的更改:

聯繫人親緣關係​​​​​​​

        從Android Q開始,該平臺不再跟蹤聯繫人親緣關係信息。因此,如果您的應用對用戶的聯繫人進行搜索,則結果不再按交互頻率排序。 “聯繫人提供程序”指南包含一個通知,說明自Android Q起所有設備上已廢棄的特定字段和方法。

MAC地址隨機化

        在Android Q 運行的設備默認傳輸隨機的MAC 地址,獲取隨機MAC地址API:WifiConfiguration.getRandomizedMacAddress()
獲取實際硬件MAC地址:WifiInfo.getFactoryMacAddress()。

唯一標識符

        應用必須具有 READ_PRIVILEGED_PHONE_STATE 特權權限才能訪問設備的不可重置標識符,包括IMEI和序列號。原則上 Android Q 建議避免使用更容易關聯到個人的硬件標識符,而是使用實例ID。實例ID的做法推薦

訪問剪貼板數據

        除非您的應用程序是默認輸入法編輯器或當前具有焦點的應用程序,否則您的應用程序無法訪問剪貼板數據。

影響針對 Android Q API 級別運行的應用的更改:

訪問USB串行需要用戶許可

        如果您的應用針對Android Q,則您的應用只能在用戶授予您訪問USB設備或配件的應用權限後才能讀取序列號。

相機和連接相關更改

        影響在Android Q 上運行的所有應用的更改:

訪問相機信息需要獲得許可

        Android Q更改了默認情況下getCameraCharacteristics()方法返回的信息的廣度。特別是,您的應用必須具有CAMERA權限才能訪問此方法的返回值中包含的潛在設備特定元數據。

啓用和禁用Wi-Fi的限制

        在Android Q上運行的應用無法啓用或停用Wi-Fi。 WifiManager.setWifiEnabled()方法始終返回false。 如果需要,請使用設置面板提示用戶啓用和禁用Wi-Fi。

 

 


影響針對 Android Q API 級別運行的應用的更改:

電話,Wi-Fi,藍牙API所需的精確位置許可

除非您的應用具有ACCESS_FINE_LOCATION權限,否則在Android Q上運行時,您的應用無法在Wi-Fi,Wi-Fi Aware或藍牙API中使用多種方法。要查看受影響方法的列表,請參閱隱私附錄。

Wi-Fi網絡配置限制

將Wi-Fi網絡列表的手動配置限制在系統應用程序中。如果您的應用針對Android Q,則以下方法不再返回有用數據,下面方法將不會返回有效信息:

  • getConfiguredNetworks()方法始終返回空List

  • addNetwork()和updateNetwork() - 始終返回-1

  • 返回布爾值的每個網絡操作 - removeNetwork(),reassociate(),enableNetwork(),disableNetwork(),reconnect()和disconnect() - 始終返回false

物理活動識別

針對 Android Q API 級別運行的應用,Android Q爲需要檢測用戶移動的應用程序(例如步行,騎自行車或車輛)引入了新的ACTIVITY_RECOGNITION運行時權限。這旨在讓用戶瞭解設置中如何使用設備傳感器數據。

 

 

 

Android Q 行爲變更

最令我們關心的,還是我們的適配工作。下面,分兩部分講:

一、針對所有運行在 Android Q 上的app的行爲變更

非SDK接口限制更新(Non-SDK interface restrictions):
爲了確保應用穩定性和兼容性,Google 在 Android O 中開始限制使用哪些非SDK接口(API級別28)。 Android Q 更新了非SDK接口的限制列表,並且修改了限制規則。
1.灰名單修改:在Android 9(API級別28)中,灰名單分爲以下兩個列表:

(1)lightgrey列表: targetSdkVersion<28 情況下可以使用的非SDK接口

(2)darkgrey list:targetSdkVersion>=28 情況下無法使用的非SDK接口

在 Android Q 中,我們現在將這兩個列表統稱爲 greylist(灰名單),但是受目標API級別限制:

如在 Android P 中被限制的黑灰色名單:darkgrey list 現在叫做 greylist-max-o,
在 Android Q 中被限制的非SDK接口應該稱爲 greylist-max-p

2.代碼註釋修改:引入以下註解來區別哪些非SDK接口在哪個API做了限制

@UnsupportedAppUsge    無限制的灰名單

@UnsupportedAppUsage(maxTargetSdk = 0)    黑名單,哪個API都不能調用

@UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.O)    API <= Android O 可以調用

@UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P)    API <= Android P 可以調用

Android Q 非SDK接口限制列表過長,這裏直接附上查詢地址

WIFI P2P 廣播(Wi-Fi Direct broadcasts):

在 Android Q 上,與 Wi-Fi Direct 功能相關的廣播不再具有粘性。如果你的 APP 依賴於在註冊時接收這些廣播,可以在初始化時使用適當的get()方法來獲取信息,具體可參考 WifiP2pManager 類相關方法。

SYSTEM_ALERT_WINDOW 權限在 Android Go 設備變更

在Android Q(Go版)設備上運行的應用無法接收SYSTEM_ALERT_WINDOW權限。這是因爲繪製疊加窗口使用過多的內存,這對低內存Android設備的性能特別有害。

二、針對API級別爲 Android Q 的行爲變更

如果你的應用將targetSdkVersion設置爲“android-Q”或更高版本,則下面的你需要注意了。

灰名單變更

灰名單變更參考“針對所有運行在 Android Q 上的app的行爲變更”的策略,意味着@UnsupportedAppUsage(maxTargetSdk < Build.VERSION_CODES.Q) 的非API方法你都需要注意了!!!

共享內存

針對Q的應用不能再直接使用ashmem(/ dev / ashmem),而必須通過NDK的ASharedMemory類訪問共享內存。此外,應用程序無法直接對現有的ashmem文件描述符進行IOCTL,而必須使用NDK的ASharedMemory類或Android Java API來創建共享內存區域。在使用共享內存時,此更改可提高安全性和穩健性,從而提高Android整體的性能和安全性。

Android runtime only accepts system-generated OAT files

Android運行時(ART)不再從應用程序進程調用dex2oat。此更改意味着ART將僅接受系統生成的OAT文件。

Permissions changes for fullscreen intents

使用全屏Intent通知的應用必須在其應用的 Manifest 文件中請求 USE_FULL_SCREEN_INTENT 權限,這是正常權限,因此係統會自動授予。 如果針對Android Q或更高版本的應用嘗試在不請求USE_FULL_SCREEN_INTENT權限的情況下創建具有全屏的Intent,系統將忽略全屏意圖。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章