Категории
Самые читаемые
ChitatKnigi.com » 🟢Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Читать онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
1 ... 531 532 533 534 535 536 537 538 539 ... 642
Перейти на страницу:

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать

Если дополнительная функциональность, предлагаемая специализированным диспетчером компоновки, не требуется, то можно просто расширить класс FrameworkElement, который обладает необходимой инфраструктурой, позволяющей содержать также и визуальные элементы. В целях иллюстрации вставьте в проект новый класс по имени CustomVisualFrameworkElement.

Унаследуйте его от FrameworkElement и импортируйте пространства имен System, System.Windows, System.Windows.Input, System.Windows.Media и System.Windows.Media.Imaging.

Класс CustomVisualFrameworkElement будет поддерживать переменную член типа VisualCollection, которая содержит два фиксированных объекта DrawingVisual (конечно, в эту коллекцию можно было бы добавлять члены с помощью мыши, но лучше сохранить пример простым). Модифицируйте код класса следующим образом:

public class CustomVisualFrameworkElement : FrameworkElement

{

<b>  // Коллекция всех визуальных объектов.</b>

  VisualCollection theVisuals;

  public CustomVisualFrameworkElement()

  {

<b>    // Заполнить коллекцию VisualCollection несколькими объектами DrawingVisual.</b>

<b>    // Аргумент конструктора представляет владельца визуальных объектов.</b>

    theVisuals = new VisualCollection(this)

      {AddRect(),AddCircle()};

  }

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

  private Visual AddCircle()

  {

    DrawingVisual drawingVisual = new DrawingVisual();

<b>    // Получить объект DrawingContext для создания нового содержимого.</b>

    using DrawingContext drawingContext =

      drawingVisual.RenderOpen()

<b>    // Создать круг и нарисовать его в DrawingContext.</b>

    drawingContext.DrawEllipse(Brushes.DarkBlue, null,

      new Point(70, 90), 40, 50);

    return drawingVisual;

  }

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

  private Visual AddRect()

  {

    DrawingVisual drawingVisual = new DrawingVisual();

    using DrawingContext drawingContext =

      drawingVisual.RenderOpen()

    Rect rect =

      new Rect(new Point(160, 100), new Size(320, 80));

    drawingContext.DrawRectangle(Brushes.Tomato, null, rect);

    return drawingVisual;

  }

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

}

Прежде чем специальный элемент FrameworkElement можно будет использовать внутри Window, потребуется переопределить два упомянутых ранее ключевых виртуальных члена, которые вызываются внутренне инфраструктурой WPF во время процесса визуализации. Метод GetVisualChild() возвращает из коллекции дочерних элементов дочерний элемент по указанному индексу. Свойство VisualChildrenCount, допускающее только чтение, возвращает количество визуальных дочерних элементов внутри визуальной коллекции. Оба члена легко реализовать, т.к. всю реальную работу можно делегировать переменной-члену типа VisualCollection:

protected override int VisualChildrenCount

  =&gt; theVisuals.Count;

protected override Visual GetVisualChild(int index)

{

  // Значение должно быть больше нуля, поэтому разумно это проверить.

  if (index &lt; 0 || index &gt;= theVisuals.Count)

  {

     throw new ArgumentOutOfRangeException();

  }

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

  return theVisuals[index];

}

Теперь вы располагаете достаточной функциональностью, чтобы протестировать специальный класс. Модифицируйте описание XAML элемента Window, добавив в существующий контейнер StackPanel один объект CustomVisualFrameworkElement. Это потребует создания специального пространства имен XML, которое отображается на пространство имен .NET Core.

&lt;Window x:Class=&quot;RenderingWithVisuals.MainWindow&quot;

  xmlns=&quot;http://schemas.microsoft.com/winfx/2006/xaml/presentation&quot;

  xmlns:x=&quot;http://schemas.microsoft.com/winfx/2006/xaml&quot;

<b>  xmlns:local=&quot;clr-namespace:RenderingWithVisuals&quot;</b>

  Title=&quot;Fun with the Visual Layer&quot; Height=&quot;350&quot; Width=&quot;525&quot;

  Loaded=&quot;Window_Loaded&quot; WindowStartupLocation=&quot;CenterScreen&quot;&gt;

    &lt;StackPanel Background=&quot;AliceBlue&quot; Name=&quot;myStackPanel&quot;&gt;

      &lt;Image Name=&quot;myImage&quot; Height=&quot;80&quot;/&gt;

<b>      &lt;local:CustomVisualFrameworkElement/&gt;</b>

    &lt;/StackPanel&gt;

&lt;/Window&gt;

Результат выполнения программы показан на рис. 26.15.

1 ... 531 532 533 534 535 536 537 538 539 ... 642
Перейти на страницу:
Отывы о книге
Открыть боковую панель
Комментарии
Ксения
Ксения 25.01.2025 - 12:30
Неплохая подборка книг. Прочитаю все однозначно.
Jonna
Jonna 02.01.2025 - 01:03
Страстно🔥 очень страстно
Ксения
Ксения 20.12.2024 - 00:16
Через чур правильный герой. Поэтому и остался один
Настя
Настя 08.12.2024 - 03:18
Прочла с удовольствием. Необычный сюжет с замечательной концовкой
Марина
Марина 08.12.2024 - 02:13
Не могу понять, где продолжение... Очень интересная история, хочется прочесть далее