Verwenden Sie den MVVM -Modus, um dynamisch eine beliebige Anzahl von Rechtecken in WPF Canvas
Modelldesign anzeigen
Implementierung anzeigen
Verwenden Sie in der Ansicht itemsControl, um die rechteckige Sammlung zu visualisieren:<code class="language-csharp">public class RectItem { public double X { get; set; } public double Y { get; set; } public double Width { get; set; } public double Height { get; set; } } public class ViewModel { public ObservableCollection<RectItem> RectItems { get; set; } }</code>
gebunden
itemsControls itemsource -Eigenschaft ist im Ansichtsmodell an die Eigenschaft der Rektiteme gebunden. Die Eigenschaften der rechteckigen Leinwand.<code class="language-xml"><ItemsControl ItemsSource="{Binding RectItems}"> <ItemsControl.ItemsPanel> <ItemsPanelTemplate> <Canvas /> </ItemsPanelTemplate> </ItemsControl.ItemsPanel> <ItemsControl.ItemContainerStyle> <Style TargetType="FrameworkElement"> <Setter Property="Canvas.Left" Value="{Binding X}" /> <Setter Property="Canvas.Top" Value="{Binding Y}" /> </Style> </ItemsControl.ItemContainerStyle> <ItemsControl.ItemTemplate> <DataTemplate> <Rectangle Fill="Black" Height="{Binding Height}" Width="{Binding Width}" /> </DataTemplate> </ItemsControl.ItemTemplate> </ItemsControl></code>
Das obige ist der detaillierte Inhalt vonWie füge ich mit MVVM mehrere Rechtecke zu einer WPF -Leinwand dynamisch hinzu?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!