Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/185.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 在XML中将ListView项设置为屏幕宽度的一半_Android_Xml_Android Layout_Android Listview_Listitem - Fatal编程技术网

Android 在XML中将ListView项设置为屏幕宽度的一半

Android 在XML中将ListView项设置为屏幕宽度的一半,android,xml,android-layout,android-listview,listitem,Android,Xml,Android Layout,Android Listview,Listitem,在XML中,我有一个自定义列表项视图,我正在为我的ListView适配器的getView()方法中扩展它。在XML中,如何使自定义ListView项始终为屏幕宽度的一半(可能还添加了一些填充)?我不认为添加另一个小部件会像我看到的建议解决方案那样有效,因为这是一个列表项 编辑: 澄清一下,我认为这不是我的xml代码的问题,但我的意思是。如果我有这样的自定义布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns

在XML中,我有一个自定义列表项视图,我正在为我的ListView适配器的getView()方法中扩展它。在XML中,如何使自定义ListView项始终为屏幕宽度的一半(可能还添加了一些填充)?我不认为添加另一个小部件会像我看到的建议解决方案那样有效,因为这是一个列表项

编辑:

澄清一下,我认为这不是我的xml代码的问题,但我的意思是。如果我有这样的自定义布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:weightSum="1.0"
    android:paddingTop="10dp" 
    >

    <ImageView
        android:id="@+id/item_image"
        android:layout_width="218dp"
        android:layout_height="212dp"
        android:layout_gravity="right"
        android:adjustViewBounds="true"

        android:scaleType="fitCenter"
        android:src="@drawable/..." />

</LinearLayout>

我有一个硬编码宽度(我不认为这是最佳实践),所以我想使该宽度为屏幕总宽度的1/2。显然,这个XML简化了很多,但我希望它能解决这个问题

如果我遗漏了一些非常明显的东西,我会道歉

编辑

添加另一个具有相同布局的布局可以解决此问题

编辑2: 不要介意。我注意到以下行为: 如果我添加另一个布局,它将使所有内容膨胀,因此我将为每个列表项获得一半的空白宽度。我必须使最上面的布局是我猜屏幕宽度的一半。我如何处理这个问题?

main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/LinearLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:orientation="vertical" >

        <ListView
            android:id="@+id/listView1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
        </ListView>
    </LinearLayout>

    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:orientation="vertical" >
    </LinearLayout>
</LinearLayout>

itemlist.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<LinearLayout
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#000000"
    android:gravity="center"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_launcher" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Large Text"
        android:textAppearance="?android:attr/textAppearanceLarge" />
</LinearLayout>

MainActivity.java

public class MainActivity extends Activity {

 static final String TAG_NAME = "name";
 static final String TAG_ID = "id";
 static String selected = "";

ListView listView;


HashMap<String, String> map;
ArrayList<HashMap<String,String>> myList;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    myList = new ArrayList<HashMap<String,String>>();       
    listView = (ListView) findViewById(R.id.listView1);
    fillListView();
}

private void fillListView() {

    myList.clear();

    map = new HashMap<String, String>();
    map.put(TAG_ID,"1");
    map.put(TAG_NAME, "Name1");
    myList.add(map);

    map = new HashMap<String, String>();
    map.put(TAG_ID,"2");
    map.put(TAG_NAME, "Name2");
    myList.add(map);

    map = new HashMap<String, String>();
    map.put(TAG_ID,"3");
    map.put(TAG_NAME, "Name3");
    myList.add(map);

    map = new HashMap<String, String>();
    map.put(TAG_ID,"4");
    map.put(TAG_NAME, "Name4");
    myList.add(map);

    listView.setAdapter(new MyListAdapter(this, R.layout.itemlist, myList));

}
private class MyListAdapter extends BaseAdapter 
{

    private List<HashMap<String,String>> List;
    private LayoutInflater mInflater;
    private int layoutresource;

    public MyListAdapter(Context context,int resource,List<HashMap<String, String>> myList) {
        List = myList;
        mInflater = LayoutInflater.from(context);
        layoutresource = resource;
    }

    @Override
    public int getCount() {
        return List.size();
    }

    @Override
    public Object getItem(int position) {
        return List.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {

        if (convertView == null) {
            convertView = mInflater.inflate(layoutresource,null);
        }    

         final View rootView = convertView.findViewById(R.id.root);

        ImageView imageView = (ImageView) convertView.findViewById(R.id.imageView1);
        final TextView name = (TextView) convertView.findViewById(R.id.textView1);

        imageView.setImageDrawable(getResources().getDrawable(R.drawable.profile));
        name.setTextColor(Color.parseColor("#ffffff"));
        name.setText(List.get(position).get(TAG_NAME));

        if ( List.get(position).get(TAG_ID).equals(selected))
            name.setTextColor(Color.parseColor("#ff0000"));
        else
            name.setTextColor(Color.parseColor("#ffffff"));


        rootView.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {

                selected = List.get(position).get(TAG_ID);
                fillListView();
            }
        });

        name.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                rootView.performClick();
            }
        });

        imageView.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                rootView.performClick();
            }
        });

        return convertView;
    }
}
公共类MainActivity扩展活动{
静态最终字符串标记_NAME=“NAME”;
静态最终字符串标记\u ID=“ID”;
选择静态字符串=”;
列表视图列表视图;
HashMap图;
ArrayList myList;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myList=新的ArrayList();
listView=(listView)findViewById(R.id.listView1);
fillListView();
}
私有void fillListView(){
myList.clear();
map=新的HashMap();
地图放置(标签ID,“1”);
地图放置(标签名称,“名称1”);
添加(地图);
map=新的HashMap();
地图放置(标签ID,“2”);
地图放置(标签名称,“名称2”);
添加(地图);
map=新的HashMap();
地图放置(标签ID,“3”);
地图放置(标签名称,“名称3”);
添加(地图);
map=新的HashMap();
地图放置(标签ID,“4”);
地图放置(标签名称,“名称4”);
添加(地图);
setAdapter(新的MyListAdapter(this,R.layout.itemlist,myList));
}
私有类MyListAdapter扩展BaseAdapter
{
私人名单;
私人停车场;
私人内部布局资源;
公共MyListAdapter(上下文上下文、int资源、列表myList){
列表=myList;
mInflater=LayoutInflater.from(上下文);
layoutresource=资源;
}
@凌驾
public int getCount(){
返回List.size();
}
@凌驾
公共对象getItem(int位置){
返回列表。获取(位置);
}
@凌驾
公共长getItemId(int位置){
返回位置;
}
@凌驾
公共视图getView(最终整数位置、视图转换视图、视图组父视图){
if(convertView==null){
convertView=mInflater.充气(布局资源,空);
}    
最终视图rootView=convertView.findViewById(R.id.root);
ImageView ImageView=(ImageView)convertView.findViewById(R.id.imageView1);
final TextView name=(TextView)convertView.findViewById(R.id.textView1);
setImageDrawable(getResources().getDrawable(R.drawable.profile));
name.setTextColor(Color.parseColor(#ffffff”);
name.setText(List.get(position.get(TAG_name));
if(List.get(position).get(TAG_ID).equals(selected))
name.setTextColor(Color.parseColor(#ff0000”);
其他的
name.setTextColor(Color.parseColor(#ffffff”);
setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
所选=列表.get(位置).get(标记ID);
fillListView();
}
});
name.setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
rootView.performClick();
}
});
setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
rootView.performClick();
}
});
返回视图;
}
}
}您的listitem中只有一个视图(imageview)。因此,您应该将listview的宽度减半,而不是列表项。但是,如果您确实希望将listitem的宽度减半,请尝试以下代码,我希望它会有所帮助

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal"
    android:weightSum="10"
    android:gravity="center"
    android:paddingTop="10dp" 
    >

    <ImageView
        android:id="@+id/item_image"
        android:layout_width="0dp"
        android:layout_weight="5"
        android:layout_height="212dp"
        android:adjustViewBounds="true"

        android:scaleType="fitCenter"
        android:src="@drawable/..." />

</LinearLayout>

简化

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
          android:id="@+id/LinearLayout1"
          android:layout_width="match_parent"
          android:layout_height="match_parent"
          android:orientation="horizontal"
          android:paddingTop="10dp">
<ImageView
        android:id="@+id/item_image"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="212dp"
        android:layout_gravity="right"
        android:adjustViewBounds="true"
        android:scaleType="fitCenter"
        android:background="#FFFFFF"
        android:src="@drawable/ic_launcher" />
<View android:layout_height="0dp"
      android:layout_width="0dp"
      android:layout_weight="1"/>
</LinearLayout>


可以添加客户布局的xml代码listview@hakiko我可以在活动中的两个列表视图之间具有50/50的宽度关系,但我正在膨胀以放入每个列表项的自定义布局在两个列表视图中都被切断,因为其宽度超过屏幕的50%。这就是我的问题。请给我们看一些代码我添加了一些代码@NezamMy问题不在主要活动中。它正在设置自定义布局列表项的宽度。是的,我也刚刚解决了这个问题。那么,我相信你的回答。谢谢。我想,没有必要添加额外的视图。我使用的额外视图使用50%的屏幕宽度。你能看到我的编辑吗?这个额外的视图也被放大了,所以我的项目变成了半个空的空间(显然是一个不利的结果),我想这样做。当我这样做的时候,我不能让它移到中心。有什么建议吗?是的,只需设置父视图的严重性。检查我的更新答案。