Android - 自定义布局在 ListView 中变得混乱
Android - Custom Layout getting messed up inside ListView
我正在制作一个应用程序,它将使用二次公式执行二次计算。为了显示求解方程的步骤,我使用 ListView
并将每个步骤作为 ListView
项。但是,我创建的用于在 ListView
中将方程显示为行的自定义布局在 运行 应用程序中变得完全混乱。
它应该是这样的:
而且,这是它的实际样子:
我只是想不通哪里出了问题,我已经尝试了在互联网上找到的所有可能的解决方案。
这是我的自定义布局的 xml 代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:layout_width="match_parent"
android:layout_height="1.5dp"
android:id="@+id/imageView2"
android:src="@drawable/line"
android:paddingLeft="50dp"
android:paddingRight="50dp"
android:layout_centerInParent="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="or,"
android:id="@+id/textView4"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:textSize="20sp"
android:paddingLeft="5dp"
android:textColor="#FFFFFF"
android:layout_centerHorizontal="true"
android:layout_alignBottom="@+id/main_equation_deno"
android:layout_alignTop="@+id/main_equation_num"
android:gravity="center_vertical" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="-b ± √(b - 4ac)"
android:id="@+id/main_equation_num"
android:textSize="30sp"
android:textColor="#FFFFFF"
android:gravity="center_vertical|center_horizontal"
android:layout_above="@+id/imageView2"
android:paddingBottom="3dp"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="2"
android:id="@+id/square"
android:layout_marginBottom="25dp"
android:textColor="#FFFFFF"
android:textSize="15sp"
android:textIsSelectable="false"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:gravity="center_horizontal"
android:layout_marginLeft="25dp"
android:layout_alignBottom="@+id/imageView2" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="2a"
android:id="@+id/main_equation_deno"
android:layout_below="@+id/imageView2"
android:textSize="30sp"
android:textColor="#FFFFFF"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:gravity="center_horizontal" />
</RelativeLayout>
这是我的列表适配器:
public class StepListAdapter extends ArrayAdapter<Step> {
private Context mContext;
private ArrayList<Step> mSteps = new ArrayList<Step>();
public StepListAdapter(Context context, ArrayList<Step> steps) {
super(context, 0, steps);
this.mContext = context;
this.mSteps = steps;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.step_row, parent, false);
TextView main_num = (TextView) view.findViewById(R.id.main_equation_num);
TextView main_deno = (TextView) view.findViewById(R.id.main_equation_deno);
main_num.setText(mSteps.get(position).getNum());
main_deno.setText(mSteps.get(position).getDeno());
return view;
}
}
非常感谢有关此问题的任何帮助。谢谢。
您可以尝试以不同的方式膨胀行:
View view = inflater.inflate(R.layout.step_row, null);
或者尝试设置最小行高。
编辑:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:minHeight="400dp">
...
尝试使用这种布局,
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000000"
android:orientation="vertical" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal|bottom" >
<TextView
android:id="@+id/main_equation_num"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="-b ± √(b - 4ac)"
android:textColor="#FFFFFF"
android:textSize="30sp" />
<TextView
android:id="@+id/square"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:text="2"
android:layout_marginLeft="105dp"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="#FFFFFF"
android:textIsSelectable="false"
android:textSize="15sp" />
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:orientation="horizontal" >
<TextView
android:id="@+id/textView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:text="or,"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="#FFFFFF"
android:textSize="20sp" />
<View
android:id="@+id/imageView2"
android:layout_width="0dp"
android:layout_height="1.5dp"
android:layout_weight="1"
android:background="#ffffff"
android:paddingLeft="50dp"
android:paddingRight="50dp" />
</LinearLayout>
<TextView
android:id="@+id/main_equation_deno"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="2a"
android:textColor="#FFFFFF"
android:textSize="30sp" />
</LinearLayout>
我对你的 xml 进行了一些更改,只需复制粘贴此 xml。
希望这对你有所帮助。
我正在制作一个应用程序,它将使用二次公式执行二次计算。为了显示求解方程的步骤,我使用 ListView
并将每个步骤作为 ListView
项。但是,我创建的用于在 ListView
中将方程显示为行的自定义布局在 运行 应用程序中变得完全混乱。
它应该是这样的:
而且,这是它的实际样子:
我只是想不通哪里出了问题,我已经尝试了在互联网上找到的所有可能的解决方案。
这是我的自定义布局的 xml 代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:layout_width="match_parent"
android:layout_height="1.5dp"
android:id="@+id/imageView2"
android:src="@drawable/line"
android:paddingLeft="50dp"
android:paddingRight="50dp"
android:layout_centerInParent="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="or,"
android:id="@+id/textView4"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:textSize="20sp"
android:paddingLeft="5dp"
android:textColor="#FFFFFF"
android:layout_centerHorizontal="true"
android:layout_alignBottom="@+id/main_equation_deno"
android:layout_alignTop="@+id/main_equation_num"
android:gravity="center_vertical" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="-b ± √(b - 4ac)"
android:id="@+id/main_equation_num"
android:textSize="30sp"
android:textColor="#FFFFFF"
android:gravity="center_vertical|center_horizontal"
android:layout_above="@+id/imageView2"
android:paddingBottom="3dp"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="2"
android:id="@+id/square"
android:layout_marginBottom="25dp"
android:textColor="#FFFFFF"
android:textSize="15sp"
android:textIsSelectable="false"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:gravity="center_horizontal"
android:layout_marginLeft="25dp"
android:layout_alignBottom="@+id/imageView2" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="2a"
android:id="@+id/main_equation_deno"
android:layout_below="@+id/imageView2"
android:textSize="30sp"
android:textColor="#FFFFFF"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:gravity="center_horizontal" />
</RelativeLayout>
这是我的列表适配器:
public class StepListAdapter extends ArrayAdapter<Step> {
private Context mContext;
private ArrayList<Step> mSteps = new ArrayList<Step>();
public StepListAdapter(Context context, ArrayList<Step> steps) {
super(context, 0, steps);
this.mContext = context;
this.mSteps = steps;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.step_row, parent, false);
TextView main_num = (TextView) view.findViewById(R.id.main_equation_num);
TextView main_deno = (TextView) view.findViewById(R.id.main_equation_deno);
main_num.setText(mSteps.get(position).getNum());
main_deno.setText(mSteps.get(position).getDeno());
return view;
}
}
非常感谢有关此问题的任何帮助。谢谢。
您可以尝试以不同的方式膨胀行:
View view = inflater.inflate(R.layout.step_row, null);
或者尝试设置最小行高。 编辑:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:minHeight="400dp">
...
尝试使用这种布局,
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000000"
android:orientation="vertical" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal|bottom" >
<TextView
android:id="@+id/main_equation_num"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="-b ± √(b - 4ac)"
android:textColor="#FFFFFF"
android:textSize="30sp" />
<TextView
android:id="@+id/square"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:text="2"
android:layout_marginLeft="105dp"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="#FFFFFF"
android:textIsSelectable="false"
android:textSize="15sp" />
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:orientation="horizontal" >
<TextView
android:id="@+id/textView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:text="or,"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="#FFFFFF"
android:textSize="20sp" />
<View
android:id="@+id/imageView2"
android:layout_width="0dp"
android:layout_height="1.5dp"
android:layout_weight="1"
android:background="#ffffff"
android:paddingLeft="50dp"
android:paddingRight="50dp" />
</LinearLayout>
<TextView
android:id="@+id/main_equation_deno"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="2a"
android:textColor="#FFFFFF"
android:textSize="30sp" />
</LinearLayout>
我对你的 xml 进行了一些更改,只需复制粘贴此 xml。
希望这对你有所帮助。