【发布时间】:2017-10-20 03:33:40
【问题描述】:
我尝试在导航标题中添加一个 imageview(个人资料图片)、2 个 textview(用户名和电子邮件)。
这是导航标题的xml代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="@dimen/nav_header_height"
android:background="@drawable/side_nav_bar"
android:gravity="bottom"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:theme="@style/ThemeOverlay.AppCompat.Dark">
<ImageView
android:id="@+id/header_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:srcCompat="@android:drawable/sym_def_app_icon" />
<TextView
android:id="@+id/header_username"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="@dimen/nav_header_vertical_spacing"
android:textAppearance="@style/TextAppearance.AppCompat.Body1" />
<TextView
android:id="@+id/header_email"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</LinearLayout>
我通过 picasso 加载图像视图,这是我加载它的代码。
private void setNavHeader() {
User user = presenter.getUser();
username.setText(user.getUsername());
email.setText(user.getEmail());
try {
Picasso.with(this)
.load(user.getUserImage())
.error(R.drawable.ic_menu_camera)
.resize(200, 200)
.into(profileImage);
}catch(Exception e){
profileImage.setImageResource(R.drawable.ic_menu_camera);
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(200, 200);
profileImage.setLayoutParams(layoutParams);
}
}
这是我的输出 但是,它只适合我的手机屏幕尺寸。当我将屏幕尺寸更改为更小的屏幕尺寸时。个人资料图片将覆盖用户名和电子邮件。如何根据屏幕大小改变头像大小不遮住用户名和邮箱?
【问题讨论】:
-
尝试为 imageview 提供固定的宽度和高度。如果图像尺寸很大,那么 wrap_content 会增加图像尺寸。以 dp 为单位给出宽度和高度
-
@DemoMail 但是我需要设置多少宽度和高度?不同的屏幕尺寸需要不同的dp值?
-
不,如果你在dp中给出大小,那么它会根据设备自动调整,你不必担心设备大小
-
give 60dp X 60dp 看看你的问题能不能解决
标签: android xml android-layout imageview screen-size