0

我有一个使用 ArrayAdapter 从 Web 服务填充的列表视图。网络服务为我提供了我需要的所有数据。有些只是纯文本视图,还有一些在 EditText 和微调器之间交替。我很容易地展示它们,同时在 EditText 字段中填写它们应得的值。

问题在于填充 Spinner 的值。我可以在适配器中定义适配器吗?此外,我的数据来自 web 服务作为作为字符串传递的 XML。

到目前为止,我的 Adapter.cs 中的 Spinner 代码:

if (item.FieldType == "OptionBOX")
    {
        Spinner SpinnerValue = (Spinner) view.FindViewById<Spinner>(Resource.Id.spinnerVal);
        SpinnerValue.Visibility = view.Visibility == ViewStates.Invisible ? ViewStates.Invisible : ViewStates.Visible;

        bool isReadOnly = bool.Parse(item.isReadOnly);

        if (isReadOnly == true)
        {
            SpinnerValue.Enabled = false;
            SpinnerValue.Focusable = false;
            SpinnerValue.FocusableInTouchMode = false;
        }
    }

我的微调器数据在 item.optbox_options 中。

为了便于理解,我的 XML 中的表格:

<Table diffgr:id="Table5" msdata:rowOrder="4">
<IdRec>5</IdRec>
<FieldId>1026</FieldId>
<FieldDesc>stanje rezervoarja</FieldDesc>
<FieldType>ComboBOX</FieldType>
<isReadOnly>true</isReadOnly>
<FieldValue>6</FieldValue>
<FieldTextValue>2/4</FieldTextValue>
<OptBox_Options>
<Options><myOPT FieldValue="1" FieldTextValue="0"/><myOPT FieldValue="2" FieldTextValue="1/4"/><myOPT FieldValue="6" FieldTextValue="2/4"/><myOPT FieldValue="7" FieldTextValue="3/4"/><myOPT FieldValue="8" FieldTextValue="4/4"/></Options>
</OptBox_Options>
</Table>

所以只是为了澄清我的需求和愿望:我可以在适配器中使用适配器吗?如果可以的话 - 怎么做?如何显示来自 OptBox_Options 行的数据?我需要在我的微调器中显示 FieldTextValue 列中的值。

4

2 回答 2

1

为什么您认为不可能Adapter在您的自定义中实例化某个地方Adapter以便您ListView在其中填充内容?您可以简单地在for the之外执行Adapterfor your 。SpinnerAdapterListView

然后你只需要想出一种解耦的方式来通过层次结构传递数据,Adapters以便所有级别都得到你想要的数据。

但是我不认为ListView设计模式适合这种交互,你可能会遇到触摸事件没有被触发的问题。我认为ExpandableListView对于您要实现的目标,设计模式将是一个更明智的选择,并且将具有更好的可用性。

你可以在这里找到一个例子ExpandableListViewExpandableListView Mono for Android

于 2013-01-22T14:02:26.573 回答
0

Resolved using:

List<string> entries = new List<string>();

String rawXML = item.OptBox_Options;

StringReader stream = null;
XmlTextReader reader = null;

DataSet xmlDS = new DataSet();
stream = new StringReader(rawXML);
// Load the XmlTextReader from the stream
reader = new XmlTextReader(stream);
xmlDS.ReadXml(reader);

DataSet myOPTvalues = new DataSet();
myOPTvalues = xmlDS;

foreach (DataRow row in myOPTvalues.Tables[0].Rows)
{
    var optItem = new PrevzemSpin();
    optItem.FieldValue = row["FieldValue"].ToString();
    if (optItem.FieldValue.Equals("")) optItem.FieldValue = null;

    optItem.FieldTextValue = row["FieldTextValue"].ToString();
    if (optItem.FieldTextValue.Equals("")) optItem.FieldTextValue = null;

    entries.Add(optItem.FieldTextValue);
    SpinnerValue.Tag = optItem.FieldValue;
}
于 2013-01-25T11:45:24.603 回答