作者:rge4688618 | 来源:互联网 | 2023-09-09 08:01
match_parent-1多Dpi适配布局消失android源码中match_parent可见FILL_PARENT-1、MATCH_PARENT-1、WRAP_CONTENT
match_parent = -1多Dpi适配布局消失
android源码中match_parent
可见FILL_PARENT=-1、MATCH_PARENT=-1、WRAP_CONTENT =-2
他们都为负数,数据类型都为整数
布局中调用
<FrameLayout xmlns:android&#61;"http://schemas.android.com/apk/res/android"xmlns:app&#61;"http://schemas.android.com/apk/res-auto"xmlns:tools&#61;"http://schemas.android.com/tools"android:id&#61;"&#64;&#43;id/content_main"android:layout_width&#61;"match_parent"android:layout_height&#61;"match_parent"android:paddingBottom&#61;"&#64;dimen/activity_vertical_margin"android:paddingLeft&#61;"&#64;dimen/activity_horizontal_margin"android:paddingRight&#61;"&#64;dimen/activity_horizontal_margin"android:paddingTop&#61;"&#64;dimen/activity_vertical_margin"app:layout_behavior&#61;"&#64;string/appbar_scrolling_view_behavior"tools:context&#61;"com.example.demo.MainActivity"tools:showIn&#61;"&#64;layout/activity_main"><TextView
android:id&#61;"&#64;&#43;id/test"android:background&#61;"&#64;color/colorAccent"android:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:layout_gravity&#61;"bottom"android:text&#61;"Hello World!" />
FrameLayout>
要确保布局的灵活性并适应各种尺寸的屏幕&#xff0c;应使用 “wrap_content” 和 “match_parent” 控制某些视图组件的宽度和高度。
使用 “wrap_content”&#xff0c;系统就会将视图的宽度或高度设置成所需的最小尺寸以适应视图中的内容&#xff0c;而 “match_parent”&#xff08;在低于 API 级别 8 的级别中称为 “fill_parent”&#xff09;则会展开组件以匹配其父视图的尺寸。
如果使用 “wrap_content” 和 “match_parent” 尺寸值而不是硬编码的尺寸&#xff0c;视图就会相应地仅使用自身所需的空间或展开以填满可用空间。此方法可让布局正确适应各种屏幕尺寸和屏幕方向。
适配多Dpi和多显示模式
private void init() {mText &#61; (TextView) findViewById(R.id.test)ViewGroup.LayoutParams lp &#61; mText.getLayoutParams()Log.d(TAG, "mText.getLayoutParams():width&#61;" &#43; lp.width)lp.width &#61; lp.width * (400 / 240)Log.d(TAG, "mText.getLayoutParams():width&#61;" &#43; lp.width)mText.setText("\n" &#43; getDisplay() &#43; "\n")}private String getDisplay() {DisplayMetrics dm &#61; new DisplayMetrics()getWindowManager().getDefaultDisplay().getMetrics(dm)return " 手机屏幕的分辨率的大小是:" &#43; dm.widthPixels &#43; "*" &#43; dm.heightPixels&#43; "\n 屏幕密度&#xff08;0.75 / 1.0 / 1.5&#xff09; " &#43; dm.density &#43;"\n 屏幕密度DPI&#xff08;120 / 160 / 240&#xff09; " &#43; dm.densityDpi}
进行dpi适配时lp.width &#61; lp.width * (400 / 240);会对布局宽高进行放缩&#xff0c;由于 (400 / 240)这个一般是density/realDpi值&#xff0c;这个值在&#xff08;-∞&#xff0c;-1]&[1,&#43;∞)时道没有什么影响
问题1&#xff1a;当&#xff08;-1,1&#xff09;之间&#xff0c;布局就会消失
原因&#xff1a;由于lp.width &#61; match_parent &#61; -1&#xff0c;且lp.width为整数类型&#xff0c;强制换换为整数&#xff0c;最后乘积 lp.width * (213 / 240) &#61; 0&#xff1b;
问题2&#xff1a;当[2,&#43;∞)之间&#xff0c;布局相当于设置为wrap_content
问题3&#xff1a;在&#xff08;-∞&#xff0c;-1]之间布局虽然不会消失&#xff0c;但是宽高就是固定的数字&#xff1b;布局会严重的变形