Проблема привязки данных Silverlight - не связана с POCO - Visifire
Надеюсь, что кто-то может помочь с немного неприятной проблемой.
У меня есть график (видимость), но я просто смотрю на него как на стандартный элемент управления данными Silverlight.
При попытке привязки непосредственно к моему объекту POCO, который содержит список<> объектов (custom), который наследуется от INotifyPropertyChanged, тогда абсолютно ничего не происходит!
При этом мой словарный класс
class GraphValue : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
private string name;
public string IndicatorName
{
get
{
return name;
}
set
{
name = value;
onPropertyChanged(this, "IndicatorName");
}
}
private double _value;
public double IndicatorValue
{
get
{
return _value;
}
set
{
_value = value;
onPropertyChanged(this, "IndicatorValue");
}
}
private void onPropertyChanged(object sender, string propertyName)
{
if (this.PropertyChanged != null)
{
PropertyChanged(sender, new PropertyChangedEventArgs(propertyName));
}
}
}
Затем я создаю список и помещаю его в класс POCO с именем ClosedSameDayList. Данные заполнены нормально, я проверил.
При окончательной настройке datacontext ничего не происходит!
MyGraph.DataContext = ClosedSameDayList.GraphValues.OrderBy(z => z.IndicatorName);
Тем не менее, вот кикер.
При выполнении следующих действий все работает:
ObservableCollection<KeyValuePair<string, double>> g = new ObservableCollection<KeyValuePair<string, double>>();
foreach (var item in ClosedSameDayList.GraphValues)
{
g.Add(new KeyValuePair<string, double>(item.IndicatorName, item.IndicatorValue));
}
MyGraph.DataContext = g.OrderBy(z => z.Key);
При этом XAML для диаграммы:
<vc:Chart xmlns:vc="clr-namespace:Visifire.Charts;assembly=SLVisifire.Charts" DataContext="{Binding}" Name="MyGraph" Height="240" BorderThickness="0" Theme="Theme2" View3D="True" ToolBarEnabled="True" >
<vc:Chart.Titles>
<vc:Title Text="My Title" />
</vc:Chart.Titles>
<vc:Chart.AxesX>
<vc:Axis Title="My Title" />
</vc:Chart.AxesX>
<vc:Chart.AxesY>
<vc:Axis Title="My Title" AxisType="Primary" />
</vc:Chart.AxesY>
<vc:Chart.Series>
<vc:DataSeries RenderAs="Column" DataSource="{Binding}">
<vc:DataSeries.DataMappings>
<vc:DataMapping MemberName="AxisXLabel" Path="IndicatorName"></vc:DataMapping>
<vc:DataMapping MemberName="YValue" Path="IndicatorValue"></vc:DataMapping>
</vc:DataSeries.DataMappings>
</vc:DataSeries>
</vc:Chart.Series>
</vc:Chart>
При этом код для ClosedSameDay
class ClosedSameDay
{
public CamlQuery CamlQuery { get; set; }
public List List { get; set; }
public ListItemCollection Listitems { get; set; }
public List<GraphValue> GraphValues { get; set; }
public ClosedSameDay()
{
GraphValues = new List<GraphValue>();
CamlQuery = new CamlQuery();
CamlQuery.ViewXml = "<View>" +
" <Method Name='ITServicedesk_Dashboard_ClosedSameday_Individuals_Readlist'/>" +
" <Query>" +
" <OrderBy>" +
" <FieldRef Name='id'/>" +
" </OrderBy>" +
" </Query>" +
" <ViewFields>" +
" <FieldRef Name='id'/>" +
" <FieldRef Name='Name'/>" +
" <FieldRef Name='Total'/>" +
" </ViewFields>" +
"</View>";
}
public void PopulateObjectData()
{
foreach (ListItem item in Listitems)
{
double value = -1;
double.TryParse(item["Total"].ToString(), out value);
if (item["Name"] != null && !string.IsNullOrEmpty(item["Name"].ToString()) && value != -1)
{
this.GraphValues.Add(new GraphValue
{
IndicatorName = item["Name"].ToString(),
IndicatorValue = value
});
}
}
}
public DataSeries BuildDataSeries()
{
ObservableCollection<KeyValuePair<string, double>> g = new ObservableCollection<KeyValuePair<string, double>>();
foreach (var item in this.GraphValues)
{
g.Add(new KeyValuePair<string, double>(item.IndicatorName, item.IndicatorValue));
}
Visifire.Charts.DataSeries ds = new Visifire.Charts.DataSeries();
ds.RenderAs = Visifire.Charts.RenderAs.Column;
ds.DataSource = g.OrderBy(i => i.Key);
Visifire.Charts.DataMapping dm = new Visifire.Charts.DataMapping();
dm.MemberName = "AxisXLabel";
dm.Path = "Key";
ds.DataMappings.Add(dm);
Visifire.Charts.DataMapping dm2 = new Visifire.Charts.DataMapping();
dm2.MemberName = "YValue";
dm2.Path = "Value";
ds.DataMappings.Add(dm2);
return ds;
}
}
2 ответа
Я закрываю этот вопрос. Используя приведенный ниже метод привязки данных путем создания DataSeries, все работало нормально
public DataSeries BuildDataSeries()
{
ObservableCollection<KeyValuePair<string, double>> g = new ObservableCollection<KeyValuePair<string, double>>();
foreach (var item in this.GraphValues)
{
g.Add(new KeyValuePair<string, double>(item.IndicatorName, item.IndicatorValue));
}
Visifire.Charts.DataSeries ds = new Visifire.Charts.DataSeries();
ds.RenderAs = Visifire.Charts.RenderAs.Column;
ds.DataSource = g.OrderBy(i => i.Key);
Visifire.Charts.DataMapping dm = new Visifire.Charts.DataMapping();
dm.MemberName = "AxisXLabel";
dm.Path = "Key";
ds.DataMappings.Add(dm);
Visifire.Charts.DataMapping dm2 = new Visifire.Charts.DataMapping();
dm2.MemberName = "YValue";
dm2.Path = "Value";
ds.DataMappings.Add(dm2);
return ds;
}
Попробуйте образец приложения "Быстрый старт с привязкой к данным " в разделе Пример Visifire .