相关单位
我们常用的资源单位有px、dp、sp、dpi,如图:
data:image/s3,"s3://crabby-images/6aa75/6aa75f9ea05102bedc3f1fd158317537d68e5c1e" alt=""
补充
发现有些视觉同学可能不大清楚开发要的视觉标注中 dp 和 px 的区别。这边说下,
px 是指像素,比如车机的物理尺寸为[1920, 720]px,像素密度为 160dpi,像素密度(dpi)为单位面积的像素数。
而 dp 是指密度无关像素(开发在代码中需要使用到的单位),我们规定在中密度(mdpi:~160dpi)的屏幕上 1dp = 1px。因此如果某个屏幕的像素密度为 480dpi,那么在这个屏幕上 1dp = 480/160 px = 3px。
但我们车机是 160dpi ,因此其 1dp = 1px。
所以在输出车机的视觉标注时,直接输出 [1920, 720]dp 的标注就行。
data:image/s3,"s3://crabby-images/9140c/9140cc54466f9b9566a1c9745a1b8b26378082f2" alt=""
Context
我们知道 Context 提供访问应用独有资源的接口,如图:
data:image/s3,"s3://crabby-images/6f131/6f1319fdb886deb4f642502f85a43d9721e5fb5e" alt=""
但从 android R 之后只能从 Activity 或者 WindowContext 来访问资源(在多窗口模式下仅这其它 Context 获取的 Configuration 可能错误)。
data:image/s3,"s3://crabby-images/3a4c5/3a4c5fae9e345ff1da129de6b05cc93f81ccf6d5" alt=""
如需要在主屏幕上添加应用覆盖的窗口,需要用 Window Context 来 inflate view 和添加 window 到 WindowManager 以便在多窗口模式下也能获取到正确的资源:
final DisplayManager dm = anyContext.getSystemServer(DisplayManager.class);
final Display primaryDisplay = dm.getDisplay(DEFAULT_DISPLAY);
final Context windowContext = anyContext.createDisplayContext(primaryDisplay);
final View overlayView = Inflater.from(windowContext).inflate(layoutXml, null);
// WindowManager.LayoutParams initialization
...
mParams.type = TYPE_APPLICATION_OVERLAY;
...
mWindowContext.getSystemService(WindowManager.class).addView(overlayView, mParams);
Resources、Configurations、Assets
通过 Context 来到 Resources 后,我们会通过 Resources 拿到 AssetManager 去查找资源,那 Resources、Configuration、Assets 分别是什么呢?
data:image/s3,"s3://crabby-images/40f4a/40f4a251acab3962bab2c4f4abdcf30a6862af08" alt=""
查询逻辑
以查找 dimens 资源为例,其流程如下:
data:image/s3,"s3://crabby-images/00083/000835810cadf0bbd66bd1fa9cd020ce91659f9c" alt=""
简单来说分为三步:
data:image/s3,"s3://crabby-images/65534/65534d02b15217a1636d5b8274e2b65bfc04516a" alt=""
解析文件目录
解析顺序和流程如下:
data:image/s3,"s3://crabby-images/90b29/90b297e66cc58c80fddf395cca4afac510172dff" alt=""
查找最优文件目录
顺序和流程如下:
data:image/s3,"s3://crabby-images/f23cc/f23ccc854cdf68160e22a00eb09b6419a98e709b" alt=""
参考:
Google Design Documentation
Google 官方:屏幕兼容性
原创文章,欢迎转载,但请注明出处
网友评论