Рисование ячеек прямоугольника в WPF ItemsControl [duplicate]

NullPointerException s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException. Они наиболее распространены, но другие способы перечислены на странице NullPointerException javadoc.

Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException, be:

public class Example {

    public static void main(String[] args) {
        Object obj = null;
        obj.hashCode();
    }

}

В первой строке внутри main я явно устанавливаю ссылку Object obj равной null. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.

(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

11
задан Philipp Eger 11 March 2014 в 13:26
поделиться

2 ответа

В правильном подходе MVVM у вас будет модель представления с абстрактным представлением списка прямоугольников, например. например:

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; }
}

Тогда у вас будет представление, которое использует ItemsControl для визуализации коллекции таких Rect элементов. Элемент ItemsControl имел бы Canvas как его ItemsPanel и соответствующие ItemContainerStyle и ItemTemplate, каждый из которых привязывается к соответствующим свойствам модели представления. Это может выглядеть так:

<ItemsControl ItemsSource="{Binding RectItems}">
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <Canvas/>
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
    <ItemsControl.ItemContainerStyle>
        <Style TargetType="ContentPresenter">
            <Setter Property="Canvas.Left" Value="{Binding X}"/>
            <Setter Property="Canvas.Top" Value="{Binding Y}"/>
        </Style>
    </ItemsControl.ItemContainerStyle>
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <Rectangle Width="{Binding Width}" Height="{Binding Height}" Fill="Black"/>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemsControl>

Альтернатива без привязок в установках стиля (которая не работает в UWP) может выглядеть так:

<ItemsControl ItemsSource="{Binding RectItems}">
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <Canvas/>
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <Rectangle Width="{Binding Width}" Height="{Binding Height}" Fill="Black">
                <Rectangle.RenderTransform>
                    <TranslateTransform X="{Binding X}" Y="{Binding Y}"/>
                </Rectangle.RenderTransform>
            </Rectangle>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemsControl>
42
ответ дан Clemens 20 August 2018 в 09:44
поделиться
  • 1
    Спасибо, подсказка с ItemsControl мне очень помогла. – Philipp Eger 11 March 2014 в 14:54
  • 2
    Кажется, я не могу заставить это работать в UWP, какие-либо идеи о том, как это сделать? Поскольку вы больше не можете использовать свойства сеттера. – Nick N. 4 October 2017 в 14:32
  • 3
    @NickN. См. Здесь: stackoverflow.com/q/40069749 . Хотя я отмечен как дубликат, я бы рекомендовал подход RenderTransform из ответа. – Clemens 4 October 2017 в 14:38

Вы можете привязать коллекцию прямоугольников к ItemControl и установить ее высоту, ширину и маржу:

<ItemsControl  ItemsSource="{Binding Path=RectangleCollection,Mode=TwoWay}">
    <ItemsControl.ItemTemplate>
        <DataTemplate >
            <Canvas>
                <Rectangle Stroke="Black" Heigth={some converter} Width={some converter} Margin={Some Converter}>
            </Canvas>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemControl>

Просто идея, чтобы вы начали ...

4
ответ дан Jose 20 August 2018 в 09:44
поделиться
Другие вопросы по тегам:

Похожие вопросы: