@+id/android:list"和"@android:id/list"的写法

本文详细介绍了Android中ListView组件的使用方法,包括布局设置、数据绑定及适配器使用等内容。适用于初学者快速掌握ListView的基本操作。

Android中的列表,当然也可以用ListView来完成所需要的功能,用法是一样的。

废话不说,来关键的。

LiveActivity本身继承了关于List操作的众多接口,我们可以方便的重写这些操作中需要的方法来实现自己需要的功能。

如果要用ListActivity,则 Activity的Layout文件中必须包括一个(只能一个)ListView,且ListView的id= "@id/android:list"。

如下代码,一个标准的ListActivity Layout文件:

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

<ListView android:id="@id/android:list"
android:layout_width="fill_parent" 
android:layout_height="fill_parent"
android:background="#00FF00"
android:layout_weight="1"
android:drawSelectorOnTop="false"/>

<TextView id="@id/android:empty"
android:layout_width="fill_parent" 
android:layout_height="fill_parent"
android:background="#FF0000"
android:text="No data"/>
</LinearLayout>

请注意 ListView与TextView的id。前面说了,

1. ListView的Id为固定不变的,为"@id/android:list“,ListActivity会根据id自动查找ListView引用;在 Activity 中使用 setListAdapter(adapter); 时就默认设置到了这个list上。如果按一般控件的写法 <ListView android:id="@+id/myListView" …… />,则需要 findViewById 先得到控件对像,再调用对像的 setListAdapter(adapter); 

2. 但如果当ListView中没有值而又想提示一句话时,那么用于指定显示提示信息的TextView的id 必须为”"@id/android:empty",提示的信息可以通过android:text进行指定。

在实际中,也可以这样写,如Android2.3中的call_detail.xml中:

     <ListView android:id="@android:id/list"
            android:layout_width="match_parent" 
            android:layout_height="match_parent"
            android:scrollbarStyle="outsideOverlay"
        />

        <ScrollView android:id="@android:id/empty"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:fillViewport="true">

            <TextView android:id="@+id/emptyText"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="@string/unknown"
                android:textSize="20sp"
                android:textColor="?android:attr/textColorSecondary"
                android:paddingLeft="10dip"
                android:paddingRight="10dip"
                android:paddingTop="10dip"
                android:gravity="center"
                android:lineSpacingMultiplier="0.92"/>

        </ScrollView>

这个写法更加实用了,可以通过在listview没有显示数据时可以用@+id/emptyText进行动态赋值,而不用像前一个例子中的将empty text固化到xml中

 

OK,关于如何布局说完了,那么如何给List绑定值,并进行操作呢?

首先我们需要确实的是,ListView的布局也完成了,并通过调用setContentView(…)进行了绑定,但直到现在我们还没有确定ListView中的第一行显示的格式是什么,是直接显示文字还是要“图文并茂”的显示。

Android系统为我们提供了多种模板进行选择(android.R.layout),如

Ø Simple_list_item_1 每项有一个TextView

Ø Simple_list_item_2 每项有两个TextView

Ø Simple_list_item_checked 带CheckView的项

Ø Simple_list_item_multiple_choise 每项有一个TextView并可以多选

Ø Simple_list_item_single_choice 每项有一个TextView,但只能进行单选。

 

但然,如果以上项模板还无法满足你的要求,那只能自定义模板了(相当简单,就是定义一个layout布局)。如果你做的asp.net的开发的话,是否对dataList控件有印象呢。如果对DataList有印象,那么理解ListView也就相当的简单了。

自定义模板可以根据自己的需要定义成任意的格式,包括图片、方案及其他可显示的View,不用多说,自己定义就好了,关键是如果使用并进行模板的绑定。

如何要对ListView进行数据绑定,必须使用到一个接口:Adapter。

其中最经常与ListView进行配合使用的有ArrayAdapter、 CursorAdapter及SimpleAdapter等。

从名称可以看出ArrayAdapter使用的是一个ArrayAdapter做为数据源,SimpleCursorAdapter使用的是一个Cursor使用数据源,都比较容易理解,那么如何使用SimpleAdapter作为数据的适配器呢。Ok,从易到难。

ArrayAdapter:

 

String[] data = { "Item1", "Item2",

        "Item3", "Item4", "Item5" };

listView.setAdapter(new ArrayAdapter<String>(this,

     android.R.layout.simple_list_item_single_choice, data));  

 

SimpleCursorAdapter:

//从数据库中查询Cursor

   cursor = adapter.getAllNotes();

   startManagingCursor(cursor);

  

   //设置要显示的数据源中的列名(需要包含在cursor中)

   String[] from = new String[] { DiaryDbAdapter.KEY_COLUMN_TITLE,

                DiaryDbAdapter.KEY_COLUMN_CREATEED };

  

   //显示的View(自定义模板中的View)

   int[] to = new int[] { R.id.txtRowTitle, R.id.txtRowCreateed };

   //绑定

   SimpleCursorAdapter notes = new SimpleCursorAdapter(this,

                R.layout.diaryrow, cursor, from, to);

   setListAdapter(notes);、

SimpleAdapter:

   SimpleAdapter将一个List做为数据源,可以让ListView进行更加个性化的显示。而List中的第一项是个Map<String,?>(用到泛型),其中Map中的每项将与ListView中的每项进行一一对应绑定。Ok,看一下构造:

   SimpleAdapter(Context context,List<? Extends Map<String,?>> data,int resource,String [] form, int [] to);

² Context:当前上下文,一般把Activity.this传递进行。

² Data: 数据源。

² Resource: 自定义的layout模板资源,可以用 R.layout.xxx获取引用。

² Form: 定义ListView中的每一项数据索引,索引来自于Map<String,?>,即指定要显示的内容。

² To:View数组,在ListView模板中的定义View,与Form中需要一一对应。

事例代码:

      List<Hashtable<String, Object>> listContent

new ArrayList<Hashtable<String, Object>>();

 

      for (int i = 0; i < deviceList.size(); i++) {

         Hashtable<String, Object> table

new Hashtable<String, Object>();

         table.put("name", deviceList.get(i).Name);

         table.put("address", deviceList.get(i).Address);

         table.put("type", deviceList.get(i).Type + "");  

 

         listContent.add(table);

      }

      adapter = new SimpleAdapter(HeartActivity.this,

listContent, R.layout.child, //自定义的layout

new String[] { "name", "address" },

new int[] {R.id.txtDeviceName, R.id.txtDeviceAddress });

 

      setListAdapter(adapter);

以上代码使用了Hashtable做为一个Map,并添加到一个List<Hashtable<String, Object>>当中。

之后new一个SimpleAdapter,注意SimpleAdapter是如何生成的。

<?xml version="1.0" encoding="utf-8"?> <ScrollView 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="match_parent" android:fillViewport="true" android:scrollbars="vertical"> <androidx.constraintlayout.widget.ConstraintLayout android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="20dp"> <TextView android:id="@+id/tv_enter_password_tips" style="@style/Widget.TPDesign.TextView.Primary.Headline4" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginHorizontal="@dimen/tpds_all_dp_20" android:layout_marginTop="@dimen/tpds_card_view_spacing" android:text="@string/wisp_join_network_title" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" /> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_ssid" style="?attr/materialCardViewStyle" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="@dimen/tpds_card_view_spacing" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/tv_enter_password_tips"> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/item_ssid" android:layout_width="match_parent" android:layout_height="wrap_content" /> </com.tplink.design.card.TPConstraintCardView> <com.tplink.design.text.TPTextField android:id="@+id/tf_wireless_ssid" style="@style/Widget.TPDesign.TextInputLayout.SingleLine" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginStart="@dimen/tpds_card_view_margin_horizontal" android:layout_marginTop="@dimen/tpds_card_view_spacing" android:layout_marginEnd="@dimen/tpds_card_view_margin_horizontal" android:hint="@string/wireless_network_name" android:visibility="gone" app:endIconMode="clear_text" app:layout_constraintTop_toBottomOf="@id/tv_enter_password_tips"> <requestFocus /> </com.tplink.design.text.TPTextField> <androidx.constraintlayout.widget.Barrier android:id="@+id/barrier_password" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical" app:barrierDirection="bottom" app:constraint_referenced_ids="card_ssid,tf_wireless_ssid" /> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_password" style="?attr/materialCardViewStyle" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="@dimen/tpds_card_view_spacing" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/barrier_password"> <com.tplink.design.text.TPInnerErrorTextField android:id="@+id/tf_password" style="@style/Widget.TPDesign.TextInputLayout.InnerError" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="@string/common_password" android:inputType="textPassword" app:innerPasswordToggleEnabled="true" /> </com.tplink.design.card.TPConstraintCardView> <TextView android:id="@+id/tv_password_tip" style="@style/Widget.TPDesign.TextView.Secondary.Body1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginStart="@dimen/tpds_card_view_margin_horizontal" android:layout_marginTop="@dimen/tpds_card_view_spacing" android:text="@string/onboarding_manual_enter_pwd_tip" android:visibility="gone" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/card_password" /> <!-- todo band,security,--> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_band" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginHorizontal="@dimen/tpds_all_dp_16" android:layout_marginTop="@dimen/tpds_all_dp_16" android:visible="false" app:layout_constraintTop_toBottomOf="@id/tv_password_tip"/> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/tl_band" android:layout_width="match_parent" android:layout_height="wrap_content" android:visibility="gone" app:itemDivider="false" app:itemEndIcon="@drawable/mp_svg_arrow_end" app:itemTitle="@string/common_band" app:layout_constraintTop_toTopOf="parent" /> </com.tplink.design.card.TPConstraintCardView> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_security" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginHorizontal="@dimen/tpds_all_dp_16" android:layout_marginTop="@dimen/tpds_all_dp_16" android:visible="false" app:layout_constraintTop_toBottomOf="@id/card_band"/> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/tl_security" android:layout_width="match_parent" android:layout_height="wrap_content" android:visibility="gone" app:itemContent="@string/advanced_dynamic_ip" app:itemDivider="false" app:itemEndIcon="@drawable/mp_svg_arrow_end" app:itemTitle="@string/m6_monthly_report_security_item_title" app:layout_constraintTop_toTopOf="parent" /> </com.tplink.design.card.TPConstraintCardView> <!-- todo 这里需要新增一个barrier 待验证是否正常--> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_advanced_setting" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginHorizontal="@dimen/tpds_all_dp_16" android:layout_marginTop="@dimen/tpds_all_dp_16" android:visible="false" app:layout_constraintTop_toTopOf="parent" /> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/tl_advanced_setting" android:layout_width="match_parent" android:layout_height="wrap_content" app:itemActionMode="switch_compact" app:itemDivider="false" app:itemTitle="@string/onboarding_usb_modem_advanced_settings" app:layout_constraintTop_toTopOf="parent" /> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/tl_front_end_ap" android:layout_width="match_parent" android:layout_height="wrap_content" android:visibility="gone" app:itemContent="@string/onboarding_auto_select_optimal_node" app:itemDivider="true" app:itemEndIcon="@drawable/mp_svg_arrow_end" app:itemTitle="@string/onboarding_mac_front_end_ap_title" app:layout_constraintTop_toBottomOf="@id/tl_advanced_setting" /> <com.tplink.design.list.TPTwoLineItemView android:id="@+id/tl_internet_connection_type" android:layout_width="match_parent" android:layout_height="wrap_content" android:visibility="gone" app:itemContent="@string/advanced_dynamic_ip" app:itemDivider="false" app:itemEndIcon="@drawable/mp_svg_arrow_end" app:itemTitle="@string/advanced_internet_connection_type" app:layout_constraintTop_toBottomOf="@id/tl_front_end_ap" /> </com.tplink.design.card.TPConstraintCardView> <com.tplink.design.card.TPConstraintCardView android:id="@+id/card_static_ip" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginHorizontal="@dimen/tpds_all_dp_16" android:layout_marginTop="@dimen/tpds_all_dp_16" android:visible="false" app:layout_constraintTop_toBottomOf="@id/card_advanced_setting"> <com.tplink.design.text.TPTextField android:id="@+id/ip_et" style="@style/Widget.TPDesign.TextInputLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:digits="0123456789." android:hint="@string/advanced_ip" android:inputType="numberDecimal" app:layout_constraintTop_toTopOf="parent" app:placeholderText="@string/common_required" /> <com.tplink.design.text.TPTextField android:id="@+id/subnet_mask_et" style="@style/Widget.TPDesign.TextInputLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:digits="0123456789." android:hint="@string/advanced_subnet_mask" android:inputType="numberDecimal" app:layout_constraintTop_toBottomOf="@id/ip_et" app:placeholderText="@string/common_required" /> <com.tplink.design.text.TPTextField android:id="@+id/gateway_et" style="@style/Widget.TPDesign.TextInputLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:digits="0123456789." android:hint="@string/advanced_default_gateway" android:inputType="numberDecimal" app:layout_constraintTop_toBottomOf="@id/subnet_mask_et" app:placeholderText="@string/common_required" /> <com.tplink.design.text.TPTextField android:id="@+id/primary_dns_et" style="@style/Widget.TPDesign.TextInputLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:digits="0123456789." android:hint="@string/advanced_primary_dns" android:inputType="numberDecimal" app:layout_constraintTop_toBottomOf="@id/gateway_et" app:placeholderText="@string/common_required" /> <com.tplink.design.text.TPTextField android:id="@+id/second_dns_et" style="@style/Widget.TPDesign.TextInputLayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:digits="0123456789." android:hint="@string/advanced_alternate_dns" android:inputType="numberDecimal" app:layout_constraintTop_toBottomOf="@id/primary_dns_et" app:placeholderText="@string/common_optional" /> </com.tplink.design.card.TPConstraintCardView> <TextView android:id="@+id/tv_no_pwd_tip" style="@style/Widget.TPDesign.TextView.Secondary.Body1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginStart="@dimen/tpds_card_view_margin_horizontal" android:layout_marginTop="@dimen/tpds_card_view_spacing" android:text="@string/onboarding_unsecured_network_tip" android:visibility="gone" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/card_static_ip" /> </androidx.constraintlayout.widget.ConstraintLayout> </ScrollView> 报错了 帮我看看哪个 标签问题 标记出来并修改
12-04
<LinearLayout android:id="@+id/device_list" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="@dimen/tpds_all_dp_16" app:layout_constraintTop_toTopOf="parent" android:orientation="horizontal"> <androidx.constraintlayout.widget.ConstraintLayout android:id="@+id/ll_site" android:layout_width="wrap_content" android:layout_height="wrap_content" android:focusable="true" android:gravity="center_horizontal" android:orientation="vertical"> <View android:id="@+id/iv_site" android:layout_width="45dp" android:layout_height="45dp" android:background="@drawable/skeleton_rounded_background" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintTop_toTopOf="parent"/> <View android:id="@+id/ll_num" android:layout_width="30dp" android:layout_height="10dp" android:layout_marginTop="4dp" android:background="@drawable/skeleton_rounded_background" app:layout_constraintTop_toBottomOf="@id/iv_site" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent"> </View> <View android:id="@+id/tv_name" android:layout_width="45dp" android:layout_height="12dp" android:layout_marginTop="4dp" android:background="@drawable/skeleton_rounded_background" android:layout_centerHorizontal="true" android:gravity="center" android:layout_below="@id/ll_num" android:textSize="@dimen/text_size_12" app:layout_constraintTop_toBottomOf="@id/ll_num" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent"> </View> </androidx.constraintlayout.widget.ConstraintLayout> </LinearLayout>我希望把5个这个约束布局平均分配在屏幕上,应该怎么写
10-15
你这样改没用,他还是那样跟原来没变化。原来是这样<?xml version="1.0" encoding="utf-8"?> <androidx.core.widget.NestedScrollView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:fillViewport="true" android:fitsSystemWindows="true" android:layout_marginTop="?attr/actionBarSize"> <!-- 根布局:ConstraintLayout 必须 match_parent 高度才能被 NestedScrollView 正确测量 --> <androidx.constraintlayout.widget.ConstraintLayout android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 🔵 垂直指南线:5%、95% --> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline_05" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" app:layout_constraintGuide_percent="0.05" /> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline_15" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" app:layout_constraintGuide_percent="0.15" /> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline_95" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" app:layout_constraintGuide_percent="0.95" /> <!-- 🔍 输入框 --> <EditText android:id="@+id/search_input" android:layout_width="0dp" android:layout_height="wrap_content" android:hint="请输入需要查询的公交线路或站点" android:textColorHint="#777777" android:textColor="@color/black" android:background="@drawable/rounded_edittext" android:minHeight="48dp" android:textSize="16sp" android:padding="12dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toStartOf="@id/search_btn" app:layout_constraintHorizontal_chainStyle="packed" app:layout_constraintTop_toTopOf="@id/guideline_05" app:layout_constraintBottom_toTopOf="@id/space_after_search" android:layout_marginStart="16dp" android:layout_marginEnd="8dp" /> <!-- 🔎 搜索按钮 --> <Button android:id="@+id/search_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="搜索" app:layout_constraintTop_toTopOf="@id/guideline_05" app:layout_constraintBottom_toTopOf="@id/space_after_search" app:layout_constraintStart_toEndOf="@id/search_input" app:layout_constraintEnd_toEndOf="parent" android:layout_marginEnd="16dp" /> <!-- ⬛ Space: 搜索栏下方留出 5% 屏幕高度作为间隔 --> <Space android:id="@+id/space_after_search" android:layout_width="match_parent" android:layout_height="0dp" app:layout_constraintTop_toBottomOf="@id/guideline_15" app:layout_constraintBottom_toTopOf="@id/map_view" app:layout_constraintHeight_percent="0.05" /> <!-- 🗺️ 地图视图:占页面 40% 高度 --> <com.amap.api.maps.MapView android:id="@+id/map_view" android:layout_width="0dp" android:layout_height="0dp" app:layout_constraintTop_toBottomOf="@id/space_after_search" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintHeight_percent="0.4" /> <!-- ⬛ Space: 地图到列表之间的空白 --> <Space android:id="@+id/space_after_map" android:layout_width="match_parent" android:layout_height="0dp" app:layout_constraintTop_toBottomOf="@id/map_view" app:layout_constraintBottom_toTopOf="@id/result_list" app:layout_constraintHeight_percent="0.03" /> <!-- 🔽 RecyclerView:结果列表,占据剩余空间 --> <androidx.recyclerview.widget.RecyclerView android:id="@+id/result_list" android:textColorHint="#777777" android:textColor="@color/black" android:layout_width="0dp" android:layout_height="wrap_content" android:background="@drawable/rounded_edittext" app:layout_constraintTop_toBottomOf="@id/space_after_map" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintBottom_toTopOf="@id/btn_go_to" android:layout_marginHorizontal="16dp" /> <!-- “到这去”按钮 --> <Button android:id="@+id/btn_go_to" android:layout_width="0dp" android:layout_height="wrap_content" android:text="到这去" android:layout_margin="16dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintBottom_toBottomOf="@id/guideline_95" /> <!-- 🌀 加载进度条:叠加在屏幕中央,不破坏原布局 --> <ProgressBar android:id="@+id/progress_bar" android:layout_width="wrap_content" android:layout_height="wrap_content" android:visibility="gone" app:layout_constraintTop_toTopOf="parent" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:elevation="10dp" /> </androidx.constraintlayout.widget.ConstraintLayout> </androidx.core.widget.NestedScrollView>
11-08
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值