我可以有效地为微调器和列表视图使用一种布局吗?
Can I effectively utilise one layout for both a spinner and a listview?
问题是我没有重新发明轶事轮子; 我想对 Spinners 和 ListView 使用相同的布局,其中列表将基于相同的数据。
我还想要一个类似的、自定义的、贯穿整个应用程序的外观,例如具有交替行颜色和根据当前核心编码的颜色的列表(Spinners 和 ListViews)activity ()。
例如。我的应用程序有商店(核心 activity),它在 ListView
(ShopName、ShopCity 和 ShopOrder)中显示为列表,用于此的布局是 R.layout.shoplist
,根据:
我的应用也有通道(另一个核心activity,所以颜色不同)。过道列表仅限于其中一个商店,因此合并了一个微调器,列出可用的商店以便 select 各自的过道。过道列表目前看起来像,没有微调器:-
我知道我可以简单地通过使用 ShopList 适配器为 Spinner 适配器中的 Spinner 指定 ShopLIst Listview 的项目布局(其中 sclcsr 是包含所有商店的 cusror , selectshoplist 是 Spinner):-
slcsr = dbshopmethods.getShops("", shopsorderby);
selectshoplistadapter = new AdapterShopList(this,
slcsr,
CursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER,
getIntent(),
true,
false
);
selectshoplist.setAdapter(selectshoplistadapter);
注意!与标准适配器相比,有 3 个额外的参数,Intent
被传递(提取的 int
用于确定使用哪个颜色范围,第一个 boolean
是一个标志指示来自 Spinner
而不是 ListView
的调用,第二个用于指示是否显示额外数据)
然而,结果是:-
那是 Spinner 的下拉列表中缺少自定义。
因此现在的问题是我需要做什么来设置下拉菜单的背景颜色?
请注意,我有一个 class (ActionColorCoding) 和方法 detremining/applying 适配器的 getView
方法中的颜色,根据: -
int evenrow = ActionColorCoding.setHeadingColor(ctxt,
callerintent,
ActionColorCoding.getColorsPerGroup() - 1
) & ActionColorCoding.transparency_evenrow;
int oddrow = evenrow & ActionColorCoding.transparency_oddrow;
if (position % 2 == 0) {
view.setBackgroundColor(evenrow);
} else {
view.setBackgroundColor(oddrow);
}
因此,以上将是要合并到适配器中的代码的基础。 Spinnner 的 Selection/selected 项目的自定义不是问题,因为这是根据 Spinner 在 activity 布局中的声明。
请注意,这个问题的目的是作为一种指南,可能对其他人提供一种似乎没有答案的技术有所帮助
Spinner 实际上有两个布局与之关联,第二个布局用于 DropDownView 并将调用方法 getDropDownView
,如果被覆盖(同时 ListViews 调用 getView
方法)。
需要注意的一件事是,如果 getDropDownView
被调用,那么 bindView
不会被调用,因此您必须调用它。
通过将以下内容添加到 ListView
适配器,您的适配器将满足 ListView
和 Spinner
:-
@Override
public View getDropDownView(int position, View convertview, ViewGroup parent) {
super.getDropDownView(position, convertview, parent);
View view = convertview;
if (fromspinner) {
int cpos = this.cursor.getPosition();
view = View.inflate(ctxt,R.layout.shoplist,null);
int evenrow = ActionColorCoding.setHeadingColor(ctxt,callerintent, ActionColorCoding.getColorsPerGroup() - 1) & ActionColorCoding.transparency_evenrow;
int oddrow = evenrow & ActionColorCoding.transparency_oddrow;
if (position % 2 == 0) {
view.setBackgroundColor(evenrow);
} else {
view.setBackgroundColor(oddrow);
}
this.cursor.moveToPosition(position);
}
bindView(view, ctxt, this.cursor);
return view;
}
注意!我认为 **if (fromspinner)**
构造不是必需的,但已作为预防措施包含在内。
补充说明,callng super.getDropDownView(position, convertview, parent);
似乎不是必需的,因此,可能是最好的说明。
注意! ctxt
、calleritent
、fromspinner
和 cursor
按照 :-
在 Adpater 的构造函数中设置
AdapterShopList(Context context,Cursor csr, int flags, Intent intent, boolean fromspinner,boolean showdetails) {
super(context, csr, 0);
ctxt = context;
callerintent = intent;
this.fromspinner = fromspinner;
this.cursor = csr;
setShopOffsets(csr);
}
你得到的结果是:-
问题是我没有重新发明轶事轮子; 我想对 Spinners 和 ListView 使用相同的布局,其中列表将基于相同的数据。
我还想要一个类似的、自定义的、贯穿整个应用程序的外观,例如具有交替行颜色和根据当前核心编码的颜色的列表(Spinners 和 ListViews)activity ()。
例如。我的应用程序有商店(核心 activity),它在 ListView
(ShopName、ShopCity 和 ShopOrder)中显示为列表,用于此的布局是 R.layout.shoplist
,根据:
我的应用也有通道(另一个核心activity,所以颜色不同)。过道列表仅限于其中一个商店,因此合并了一个微调器,列出可用的商店以便 select 各自的过道。过道列表目前看起来像,没有微调器:-
我知道我可以简单地通过使用 ShopList 适配器为 Spinner 适配器中的 Spinner 指定 ShopLIst Listview 的项目布局(其中 sclcsr 是包含所有商店的 cusror , selectshoplist 是 Spinner):-
slcsr = dbshopmethods.getShops("", shopsorderby);
selectshoplistadapter = new AdapterShopList(this,
slcsr,
CursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER,
getIntent(),
true,
false
);
selectshoplist.setAdapter(selectshoplistadapter);
注意!与标准适配器相比,有 3 个额外的参数,Intent
被传递(提取的 int
用于确定使用哪个颜色范围,第一个 boolean
是一个标志指示来自 Spinner
而不是 ListView
的调用,第二个用于指示是否显示额外数据)
然而,结果是:-
那是 Spinner 的下拉列表中缺少自定义。
因此现在的问题是我需要做什么来设置下拉菜单的背景颜色?
请注意,我有一个 class (ActionColorCoding) 和方法 detremining/applying 适配器的 getView
方法中的颜色,根据: -
int evenrow = ActionColorCoding.setHeadingColor(ctxt,
callerintent,
ActionColorCoding.getColorsPerGroup() - 1
) & ActionColorCoding.transparency_evenrow;
int oddrow = evenrow & ActionColorCoding.transparency_oddrow;
if (position % 2 == 0) {
view.setBackgroundColor(evenrow);
} else {
view.setBackgroundColor(oddrow);
}
因此,以上将是要合并到适配器中的代码的基础。 Spinnner 的 Selection/selected 项目的自定义不是问题,因为这是根据 Spinner 在 activity 布局中的声明。
请注意,这个问题的目的是作为一种指南,可能对其他人提供一种似乎没有答案的技术有所帮助
Spinner 实际上有两个布局与之关联,第二个布局用于 DropDownView 并将调用方法 getDropDownView
,如果被覆盖(同时 ListViews 调用 getView
方法)。
需要注意的一件事是,如果 getDropDownView
被调用,那么 bindView
不会被调用,因此您必须调用它。
通过将以下内容添加到 ListView
适配器,您的适配器将满足 ListView
和 Spinner
:-
@Override
public View getDropDownView(int position, View convertview, ViewGroup parent) {
super.getDropDownView(position, convertview, parent);
View view = convertview;
if (fromspinner) {
int cpos = this.cursor.getPosition();
view = View.inflate(ctxt,R.layout.shoplist,null);
int evenrow = ActionColorCoding.setHeadingColor(ctxt,callerintent, ActionColorCoding.getColorsPerGroup() - 1) & ActionColorCoding.transparency_evenrow;
int oddrow = evenrow & ActionColorCoding.transparency_oddrow;
if (position % 2 == 0) {
view.setBackgroundColor(evenrow);
} else {
view.setBackgroundColor(oddrow);
}
this.cursor.moveToPosition(position);
}
bindView(view, ctxt, this.cursor);
return view;
}
注意!我认为 **if (fromspinner)**
构造不是必需的,但已作为预防措施包含在内。
补充说明,callng super.getDropDownView(position, convertview, parent);
似乎不是必需的,因此,可能是最好的说明。
注意! ctxt
、calleritent
、fromspinner
和 cursor
按照 :-
AdapterShopList(Context context,Cursor csr, int flags, Intent intent, boolean fromspinner,boolean showdetails) {
super(context, csr, 0);
ctxt = context;
callerintent = intent;
this.fromspinner = fromspinner;
this.cursor = csr;
setShopOffsets(csr);
}
你得到的结果是:-