Android 8.1(API级别27)为用户和开发人员引入了各种新特性和功能。本文档重点介绍了开发人员的新功能。
本文主要涉及以下内容:
Android Go 简介
人工智能神经网络 API(如:TensorFlow)
自动填充框架更新
Notification 通知变更
EditText 更新
WebView 安全浏览更新
视频缩略图提取器更新
共享内存API
WallpaperColors API
指纹更新
欢迎关注微信公众号:程序员Android
微信公众号:ProgramAndroid
我们不是牛逼的程序员,我们只是程序开发中的垫脚石。
1. Android Go 简介
Android Go 系统截图
Android Go是Google 为优化Android用户体验,在Android O之上开发的一个兼容性更强的版本。从Android 8.1开始,Go版本将使Android成为入门级设备的绝佳平台。
Android Oreo(Go版)配置中的功能包括:
内存优化
改善整个平台的内存使用情况,确保应用程序可以在1GB或更少RAM的设备上高效运行。
灵活的定位选项
新的硬件功能常量,可让您通过Google Play将应用程序分配到普通或低RAM设备。
Google 已经更新了数十亿开发指南,并提供了关于如何针对运行Android Oreo(Go版)的设备优化应用的其他指导。对于大多数开发者来说,优化现有的APK,或使用Google Play的功能,将您的APK版本定位到低内存设备是准备运行Android Oreo(Go版)的最佳方式。
2. 人工智能神经网络API(如:TensorFlow)
Neural Networks API为设备上的机器学习框架(如TensorFlow Lite-Google的移动平台ML库以及Caffe2等)提供了加速的计算和推理。访问TensorFlow Lite开源回购下载和文档。 TensorFlow Lite可与Neural Networks API协同工作,在移动设备上高效运行MobileNets,Inception v3和Smart Reply等模型。
3. 自动填充框架更新
Android 8.1(API级别27)对自动填充框架进行了一些改进,您可以将其添加到应用程序中。
BaseAdapter
类现在包含setAutofillOptions()
方法,该方法允许您在Adapter
中提供值的string
表示形式。这对于在其适配器中动态生成值的微调控件非常有用。setAutofillOptions()
方法提供用户可以选择作为信用卡过期日期一部分的年数列表的字符串表示形式。自动填充服务可以使用字符串表示来适当填写需要数据的视图。
此外,AutofillManager
类还包括可以调用的notifyViewVisibilityChanged(View,int,boolean)
方法,以通知框架关于虚拟结构中视图可见性的更改。非虚拟结构的方法也有重载。但是,非虚拟结构通常不要求您显式通知框架,因为该方法已被View
类调用。
通过在SaveInfo
中添加对CustomDescription
和Validator
的支持,Android 8.1还使Autofill Services
能够更自定义保存UI可供性。
自定义描述可帮助自动填充服务澄清正在保存的内容;例如,当屏幕包含信用卡时,它可以显示信用卡银行的标志,信用卡号码的最后四位数字和到期号码。要了解更多信息,请参阅CustomDescription
类。
当Validator
条件不满足时,Validator
对象用于避免显示自动填充保存UI。要了解更多信息,请参阅Validator类及其子类LuhnChecksumValidator和RegexValidator
4. Notification 通知变更
Android 8.1包含对通知的以下更改:
应用程序现在只能每秒发出一次通知警报声。超过这个速度的警报声音不会排队并丢失。此更改不会影响通知行为的其他方面,通知邮件仍按预期发布。ActivityManager.isLowRamDevice()
时,低内存的Android设备不支持NotificationListenerService
和ConditionProviderService
,它们返回true。
5. EditText 更新
从API级别27开始,EditText.getText()
方法返回一个Editable
;以前它返回一个CharSequence
。这个改变是向后兼容的,因为Editable
实现了CharSequence
。
可编辑界面提供了有价值的附加功能。例如,由于“可编辑”也实现了Spannable接口,因此可以将标记应用于EditText实例中的内容。
6. WebView 安全浏览更新
通过·WebView·实现Safe Browsing API
,您的应用程序可以检测WebView实例
何时尝试导航到Google已被归类为已知威胁的URL。WebView
将显示一个插页式广告,警告用户已知的威胁。该屏幕允许用户选择加载URL,或返回到安全的上一页。
在Android 8.1中,您可以通过编程来定义您的应用程序如何响应已知的威胁:
您可以控制您的应用是否将已知威胁报告给安全浏览。
注意:
WebView
对象的loadUrl()
方法之前初始化安全浏览。
以下代码片段显示如何指示应用程序的WebView实例在遇到已知威胁后总是返回到安全状态:
AndroidManifest.xml
<manifest>
<application>
...
<meta-data android:name="android.webkit.WebView.EnableSafeBrowsing"
android:value="true" />
</application>
</manifest>
MyWebActivity.java
private WebView mSuperSafeWebView;
private boolean mSafeBrowsingIsInitialized;
// ...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mSuperSafeWebView = new WebView(this);
mSuperSafeWebView.setWebViewClient(new MyWebViewClient());
mSafeBrowsingIsInitialized = false;
mSuperSafeWebView.startSafeBrowsing(this, new ValueCallback<Boolean>() {
@Override
public void onReceiveValue(Boolean success) {
mSafeBrowsingIsInitialized = true;
if (!success) {
Log.e("MY_APP_TAG", "Unable to initialize Safe Browsing!");
}
}
});
}
MyWebViewClient.java
public class MyWebViewClient extends WebViewClient {
// Automatically go "back to safety" when attempting to load a website that
// Safe Browsing has identified as a known threat. An instance of WebView
// calls this method only after Safe Browsing is initialized, so there's no
// conditional logic needed here.
@Override
public void onSafeBrowsingHit(WebView view, WebResourceRequest request,
int threatType, SafeBrowsingResponse callback) {
// The "true" argument indicates that your app reports incidents like
// this one to Safe Browsing.
callback.backToSafety(true);
Toast.makeText(view.getContext(), "Unsafe web page blocked.",
Toast.LENGTH_LONG).show();
}
}
7. 视频缩略图提取器更新
MediaMetadataRetriever
类有一个新方法getScaledFrameAtTime()
,它在给定的时间位置附近找到一个帧,并返回一个与源帧具有相同纵横比的位图,但是缩放到适合于给定宽度和高度的矩形。这对于从视频生成缩略图图像很有用。
我们推荐使用这种方法而不是getFrameAtTime()
,这会浪费内存,因为它会返回一个与源视频具有相同分辨率的位图。例如,来自4K视频的帧将是一个16MB的位图,比您需要的缩略图大得多
8. 共享内存API
Android 8.1(API级别27)引入了一个新的SharedMemory API
。这个类允许你创建,映射和管理一个匿名的SharedMemory
实例。在SharedMemory
对象上设置内存保护以便读取和/或写入,并且由于SharedMemory
对象是Parcelable
,因此可以通过AIDL
轻松地将其传递给另一个进程。
SharedMemory API
与NDK中的ASharedMemory
工具交互操作。 ASharedMemory
允许访问文件描述符,然后可以将其映射为读取和写入。这是在应用程序之间或单个应用程序内的多个进程之间共享大量数据的好方法。
9. WallpaperColors API
Android 8.1(API等级27)允许您的动态壁纸为系统UI提供颜色信息。您可以通过从Bitmap,drawable
或RGB
创建WallpaperColors
对象来实现此目的。你也可以检索这个颜色信息。
要创建WallpaperColors
对象,请执行以下任一操作:
要使用三种颜色创建
WallpaperColors
对象,请通过传递主要颜色,辅助颜色和第三层颜色来创建WallpaperColors
类的实例。原色不能为空。要从位图创建
WallpaperColors
对象,请通过传递位图源作为参数来调用fromBitmap()
方法。要从
drawable
创建WallpaperColors对
象,请通过传递可绘制的源作为参数来调用fromDrawable()
方法。
-1. 要从壁纸检索主要,次要或第三个颜色细节,请调用以下方法:
getPrimaryColor()
返回最具视觉效果的壁纸颜色。getSecondaryColor()
返回第二个最显着的壁纸的颜色。getTertiaryColor()
方法返回壁纸的第三个最显着的颜色。
要通知系统有关活动壁纸中的任何重大颜色变化,请调用
notifyColorsChanged()
方法。onComputeColors()
生命周期事件,你可以提供一个新的WallpaperColors
对象。
要为颜色更改添加侦听器,可以调用
addOnColorsChangedListener()
方法。您也可以调用getWallpaperColors()
方法来检索墙纸的主要颜色。
10. 指纹更新
FingerprintManager类引入了以下错误代码:
FINGERPRINT_ERROR_LOCKOUT_PERMANENT - 用户尝试使用指纹读取器解锁设备的次数过多。
FINGERPRINT_ERROR_VENDOR - 发生特定于供应商的指纹识别器错误
感谢您的阅读,谢谢!
欢迎关注微信公众号:程序员Android
微信公众号:ProgramAndroid
我们不是牛逼的程序员,我们只是程序开发中的垫脚石。
点击阅读原文,获取更多福利