gpt4 book ai didi

java - 更改 ExpandableListView 中指示器的位置导致问题

转载 作者:太空宇宙 更新时间:2023-11-03 12:19:53 25 4
gpt4 key购买 nike

我试图将我的指示器设置在 TextView 旁边,但我无法获得正确的代码来执行此操作。

XML:

<TextView
android:id="@+id/lblListHeader"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:paddingLeft="?android:attr/expandableListPreferredItemPaddingLeft"
android:textColor="#000000"
android:textSize="17dp" />

<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_toLeftOf="@+id/lblListHeader"
android:src="@drawable/custom_arrow" />

这是我发现的唯一一堆代码,但我无法让它工作:

//inside getGropView method
View v;
if (convertView == null) {
v = newGroupView(isExpanded, parent);
} else {
v = convertView;
}
bindView(v, mGroupData.get(groupPosition), mGroupFrom, mGroupTo);
((ImageView) v.findViewById(R.id.videos_group_indicator))
.setImageResource(isExpanded?R.drawable.videos_chevron_expanded:R.drawable.videos_chevron_collapsed);
return v;

主要问题是它“强调”了 newGroupView 方法等,因为我没有这样的方法,而且在 example 中也没有提到如何创建它。我在看。

此外,一旦我得到解决方案,有人可以尝试向我解释这段代码吗?我已经阅读了很多时间,但我还是无法理解它,我是一个初学者。

最佳答案

这是自定义可扩展 ListView 的示例:

如果在新项目中应用此代码,您想看到什么:

enter image description here

将此代码创建到 Activity 中

public class ExpActivity extends Activity
{

@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

// Находим наш list
ExpandableListView listView = (ExpandableListView)findViewById(R.id.exListView);

//Создаем набор данных для адаптера
ArrayList<ArrayList<String>> groups = new ArrayList<ArrayList<String>>();
ArrayList<String> children1 = new ArrayList<String>();
ArrayList<String> children2 = new ArrayList<String>();
children1.add("Child_1");
children1.add("Child_2");
groups.add(children1);
children2.add("Child_1");
children2.add("Child_2");
children2.add("Child_3");
groups.add(children2);
//Создаем адаптер и передаем context и список с данными
ExpListAdapter adapter = new ExpListAdapter(getApplicationContext(), groups);
listView.setAdapter(adapter);
}
}

将 expandableListView 添加到 main.xml 中

<?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"
>
<ExpandableListView
android:id="@+id/exListView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:indicatorLeft="250dp"
android:indicatorRight="300dp"
/>
</LinearLayout>

创建适配器类

public class ExpListAdapter extends BaseExpandableListAdapter {

private ArrayList<ArrayList<String>> mGroups;
private Context mContext;

public ExpListAdapter (Context context,ArrayList<ArrayList<String>> groups){
mContext = context;
mGroups = groups;
}

@Override
public int getGroupCount() {
return mGroups.size();
}

@Override
public int getChildrenCount(int groupPosition) {
return mGroups.get(groupPosition).size();
}

@Override
public Object getGroup(int groupPosition) {
return mGroups.get(groupPosition);
}

@Override
public Object getChild(int groupPosition, int childPosition) {
return mGroups.get(groupPosition).get(childPosition);
}

@Override
public long getGroupId(int groupPosition) {
return groupPosition;
}

@Override
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}

@Override
public boolean hasStableIds() {
return true;
}

@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView,
ViewGroup parent) {

if (convertView == null) {
LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.group_view, null);
}

if (isExpanded){
//Изменяем что-нибудь, если текущая Group раскрыта
}
else{
//Изменяем что-нибудь, если текущая Group скрыта
}

TextView textGroup = (TextView) convertView.findViewById(R.id.textGroup);
textGroup.setText("Group " + Integer.toString(groupPosition));

return convertView;

}

@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild,
View convertView, ViewGroup parent) {
if (convertView == null) {
LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.child_view, null);
}

TextView textChild = (TextView) convertView.findViewById(R.id.textChild);
textChild.setText(mGroups.get(groupPosition).get(childPosition));

Button button = (Button)convertView.findViewById(R.id.buttonChild);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Toast.makeText(mContext,"button is pressed",5000).show();
}
});

return convertView;
}

@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}
}

方法和参数的名称非常有用。方法 getGroupView 和 getChildView 相应地为 pparentschildren 返回 View 。使用方法getGroupView中的参数isExpanded,我们可以,例如,改变不同状态的组的背面。使用 LayoutInflater,我们为我们的列表使用自定义布局。

group_view.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">
<TextView
android:id="@+id/textGroup"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_marginLeft="5dp"
android:layout_marginTop="20dp"
android:textColor="@android:color/white"
android:textStyle="bold"
/>
</LinearLayout>

child_view.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">
<TextView
android:id="@+id/textChild"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_marginLeft="20dp"
android:layout_marginTop="20dp"
android:textColor="@android:color/white"
/>
<Button
android:id="@+id/buttonChild"
android:layout_width="100dp"
android:layout_height="40dp"
android:layout_marginLeft="150dp"
android:layout_marginTop="10dp"
android:text="Button"
android:focusable="false"
/>
</LinearLayout>

在 subview 中我们添加了一个按钮,在适配器方法 getChildView 中控制它的按下。以类似的方式,我们可以在 group_view.xml 中添加按钮和其他元素。

此外,我们可以将听众固定到我们的列表。

•OnChildClickListener — 按下一个元素•OnGroupCollapseListener——折叠组•OnGroupExpandListener – 扩展组•OnGroupClickListener – 按组

现在让我们看一下 groupIndicater - 组状态的指示器。它的位置指向 main.xml 中的参数 indicatorLeft、indicatorRigh - 对应于左右边框。默认情况下指示器放置在左侧,这不是很酷。

我们还可以添加自定义图像,为此,我们需要使用此代码在可绘制文件夹中添加 indicator.xml。

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_expanded="true"
android:drawable="@drawable/imageOpen">
</item>
<item android:state_empty="true"
android:drawable="@drawable/imageClose">
</item>
</selector>

其中 imageOpen 用于扩展组imageClose 用于折叠组

下次我们需要在 main.xml 中为列表的参数添加一行

android:groupIndicator="@drawable/indicator"

关于java - 更改 ExpandableListView 中指示器的位置导致问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18941405/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com