我的目标是API等级21,而min也是21(我现在只支持Lollipop,这是一个需要学习的宠物项目)。 我遇到了自定义ListView项目布局的问题。这是我的XML:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/test_list_item_icon"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_centerVertical="true"
android:layout_marginEnd="10dp"
android:background="#FF0000"
android:src="@drawable/ic_test"
tools:ignore="ContentDescription"/>
<TextView
android:id="@+id/test_list_item_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toEndOf="@id/test_list_item_icon"
android:textSize="50sp"/>
</RelativeLayout>
这就是它的样子(图标的红色背景颜色仅用于查看实际视图的大小):
我希望图像视图的行为如下:占据布局“开始”/左侧的可用垂直空间,按比例缩放图像,并增加宽度,使图像可以完全显示,像这样(原谅我的gimp技能):
有可能吗?
答案 0 :(得分:1)
最后我决定创建另一个图标大小xxxhdpi,现在看起来都很好看。 非常感谢@ corsair992获取有关其中一条评论中的错误的信息。
答案 1 :(得分:0)
试试ImageView
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/test_list_item_icon"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_centerVertical="true"
android:layout_marginEnd="10dp"
android:background="#FF0000"
android:src="@drawable/ic_test"
android:adjustViewBounds="true"
android:scaleType="fitXY"
tools:ignore="ContentDescription"/>
<TextView
android:id="@+id/test_list_item_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toEndOf="@id/test_list_item_icon"
android:textSize="50sp"/>
</RelativeLayout>
答案 2 :(得分:0)
HI wujek您遇到问题的原因是您将高度设置为相对布局的换行内容。所以它将textview的高度作为其高度。然后图像视图将使用它作为其高度。所以改变相对布局高度以匹配父级。请尝试让我知道谢谢
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<ImageView
android:id="@+id/test_list_item_icon"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_centerVertical="true"
android:layout_marginEnd="10dp"
android:adjustViewBounds="true"
android:background="#ff0000"
android:src="@drawable/ic_launcher"
tools:ignore="ContentDescription" />
<TextView
android:id="@+id/test_list_item_name"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_toRightOf="@+id/layout_1"
android:gravity="center"
android:text="bhsbd"
android:textSize="50sp" />
答案 3 :(得分:0)
试试这个
如果您想要图片,请使用imageview
尺寸使用background
insted src
。
如果必须使用红色背景,请使用其他relative layout
作为imageview
的父级。
希望它适用于你..
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<RelativeLayout
android:id="@+id/layout_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:background="#FF0000" >
<ImageView
android:id="@+id/test_list_item_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="10dp"
android:background="@drawable/ic_launcher"
android:adjustViewBounds="true"
tools:ignore="ContentDescription" />
</RelativeLayout>
<TextView
android:id="@+id/test_list_item_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@+id/layout_1"
android:textSize="50sp" />
</RelativeLayout>
编辑2
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<RelativeLayout
android:id="@+id/layout_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/test_list_item_name"
android:layout_alignTop="@+id/test_list_item_name"
android:background="#FF0000" >
<ImageView
android:id="@+id/test_list_item_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:src="@drawable/ic_launcher"
android:adjustViewBounds="true"
tools:ignore="ContentDescription" />
</RelativeLayout>
<TextView
android:id="@+id/test_list_item_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/layout_1"
android:textSize="50sp"
android:text=" text 5>" />
</RelativeLayout>
答案 4 :(得分:-1)
使用weightsum定义LineatLayout。
<LinearLauyout
----
android:orientation="horizontal"
android:weightSum="5">
<ImageView
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1">
<TextView
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="4">
</LinearLayout>
您可以根据自己的要求调整权重。