まず、達成したい目標を説明します。連続データ ストリームを視覚化したいと考えています (1 秒あたり最大 1000 値ですが、減らすことができます)。このデータ ストリームはグラフとして視覚化する必要があります。より正確には、ECG の視覚化です。私の最初のアイデアは、ポリラインを使用してポイント コレクションにバインドすることでした。ここでの問題は、UI に何も表示されないことです。おそらく、このタスクのアプローチは間違っています。より良いアイデアを歓迎します。これまでのところ、私のコードは次のとおりです。最初のビュー:
<Canvas>
<Polyline Points="{Binding Points}" Stroke="Red" StrokeThickness="2" />
</Canvas>
簡単にするために、MVVM パターンを使用していますが、コード ビハインドを使用しています。それが、ポリラインの名前だけでなくバインディングを使用して値を追加したい理由でもあります。
public partial class MainWindow : Window
{
private short[] data = new short[]{ 10,30,50,70,90,110,130,150,170,190,210 };
private short[] data1 = new short[] { 15,14,16,13,17,12,18,11,19,10,24 };
public MainWindow()
{
InitializeComponent();
for (int i = 0; i < data.Length; i++)
{
Points.Add(new Point(data[i], data1[i]));
}
}
private PointCollection _points = new PointCollection();
public PointCollection Points
{
get { return _points; }
}
}
私はそれが良いコーディングスタイルではないことを知っていますが、最初のテストでは十分です。x 値には配列データを使用し、y 値には data1 を使用します。そのバインディングの何が問題なのか誰か教えてもらえますか? 新しい値が発生するたびに、ビューを継続的に更新するにはどうすればよいでしょうか? 事前にご協力いただきありがとうございます。
[新しいバージョンを更新] ビュー:
<Window.Resources>
<my:PointCollectionConverter x:Key="myPointsConverter"/>
</Window.Resources>
<Grid Name="grid">
<Polyline x:Name="ekglineI" Points="{Binding Points, Converter={StaticResource myPointsConverter}}" Stroke="Red" StrokeThickness="2" />
<Button Content="Button" Click="button1_Click" />
</Grid>
起動時と後でボタンがクリックされたときにポリラインを描画するコード ビハインド。
public partial class MainWindow : Window, INotifyPropertyChanged
{
private short[] data = new short[] { 10, 30, 50, 70, 90, 110, 130, 150, 170, 190, 210 };
private short[] data2 = new short[] { 230, 250, 270, 290, 300, 310, 330, 350, 370, 390, 410 };
private short[] data1 = new short[] { 15, 14, 16, 13, 17, 12, 18, 11, 19, 10, 24 };
public MainWindow()
{
InitializeComponent();
grid.DataContext = this;
for (int i = 0; i < data.Length; i++)
{
Points.Add(new Point(data[i], data1[i]));
}
}
public event PropertyChangedEventHandler PropertyChanged;
private ObservableCollection _points = new ObservableCollection();
public ObservableCollection Points
{
get { return _points; }
}
private void button1_Click(object sender, RoutedEventArgs e)
{
for (int i = 0; i < data2.Length; i++)
{
Points.Add(new Point(data2[i], data1[i]));
}
PropertyChanged(this, new PropertyChangedEventArgs("Points"));
}
今、私がやりたいことは、この行を取り除くことです: grid.DataContext = this;
MVVM を使用できるようにしますか、それとも別の可能性がありますか?