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

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

На нашем литературном портале можно бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю, Троелсен Эндрю . Жанр: Базы данных. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале litmir.org.
Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
Название: Язык программирования C#9 и платформа .NET5
Дата добавления: 22 август 2024
Количество просмотров: 172
Читать онлайн

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних просмотр данного контента СТРОГО ЗАПРЕЩЕН! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту readbookfedya@gmail.com для удаления материала

Язык программирования C#9 и платформа .NET5 читать книгу онлайн

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

В 10-м издании книги описаны новейшие возможности языка C# 9 и .NET 5 вместе с подробным "закулисным" обсуждением, призванным расширить навыки критического мышления разработчиков, когда речь идет об их ремесле.

Книга охватывает ASP.NET Core, Entity Framework Core и многое другое наряду с последними обновлениями унифицированной платформы .NET, начиная с улучшений показателей производительности настольных приложений Windows в .NET 5 и обновления инструментария XAML и заканчивая расширенным рассмотрением файлов данных и способов обработки данных.

Все примеры кода были переписаны с учетом возможностей последнего выпуска C# 9.

Перейти на страницу:

Построение кисти DrawingBrush с использованием геометрических объектов

Ранее в главе элемент Path заполнялся группой геометрических объектов примерно так:

<Path Fill = "Orange" Stroke = "Blue" StrokeThickness = "3">

  <Path.Data>

    <GeometryGroup>

      <EllipseGeometry Center = "75,70" RadiusX = "30" RadiusY = "30" />

   <RectangleGeometry Rect = "25,55 100 30" />

    <LineGeometry StartPoint="0,0" EndPoint="70,30" />

    <LineGeometry StartPoint="70,30" EndPoint="0,30" />

  </GeometryGroup>

  </Path.Data>

</Path>

Поступая подобным образом, вы достигаете интерактивности Path при чрезвычайной легковесности, присущей геометрическим объектам. Однако если необходимо визуализировать аналогичный вывод и отсутствует потребность в любой (готовой) интерактивности, тогда тот же самый элемент <GeometryGroup> можно поместить внутрь DrawingBrush:

<DrawingBrush>

  <DrawingBrush.Drawing>

    <GeometryDrawing>

      <GeometryDrawing.Geometry>

        <GeometryGroup>

          <EllipseGeometry Center = "75,70" RadiusX = "30" RadiusY = "30" />

          <RectangleGeometry Rect = "25,55 100 30" />

          <LineGeometry StartPoint="0,0" EndPoint="70,30" />

          <LineGeometry StartPoint="70,30" EndPoint="0,30" />

        </GeometryGroup>

      </GeometryDrawing.Geometry>

<b>      &lt;!-- Специальное перо для рисования границ --&gt;</b>

      &lt;GeometryDrawing.Pen&gt;

        &lt;Pen Brush=&quot;Blue&quot; Thickness=&quot;3&quot;/&gt;

      &lt;/GeometryDrawing.Pen&gt;

<b>      &lt;!-- Специальная кисть для заполнения внутренней области --&gt;</b>

      &lt;GeometryDrawing.Brush&gt;

        &lt;SolidColorBrush Color=&quot;Orange&quot;/&gt;

      &lt;/GeometryDrawing.Brush&gt;

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

    &lt;/GeometryDrawing&gt;

  &lt;/DrawingBrush.Drawing&gt;

&lt;/DrawingBrush&gt;

При помещении группы геометрических объектов внутрь DrawingBrush также понадобится установить объект Pen, применяемый для рисования границ, потому что свойство Stroke больше не наследуется от базового класса Shape. Здесь был создан элемент Pen с теми же настройками, которые использовались в значениях Stroke и StrokeThickness из предыдущего примера Path.

Кроме того, поскольку свойство Fill больше не наследуется от класса Shape, нужно также применять синтаксис "элемент-свойство" для определения объекта кисти, предназначенного элементу DrawingGeometry, со сплошным оранжевым цветом, как в предыдущих настройках Path.

Рисование с помощью DrawingBrush

Теперь объект DrawingBrush можно использовать для установки значения любого свойства, требующего объекта кисти. Например, после подготовки следующей разметки в редакторе Kaxaml с помощью синтаксиса "элемент-свойство" можно рисовать изображение по всей поверхности Page:

&lt;Page

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

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

  &lt;Page.Background&gt;

<b>    &lt;DrawingBrush&gt;</b>

<b>      &lt;!-- Тот же самый объект DrawingBrush, что и ранее --&gt;</b>

<b>    &lt;/DrawingBrush&gt;</b>

  &lt;/Page.Background&gt;

&lt;/Page&gt;

Или же элемент DrawingBrush можно применять для установки другого совместимого с кистью свойства, такого как свойство Background элемента Button:

&lt;Page

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

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

  &lt;Button Height=&quot;100&quot; Width=&quot;100&quot;&gt;

  &lt;Button.Background&gt;

<b>    &lt;DrawingBrush&gt;</b>

<b>      &lt;!-- Тот же самый объект DrawingBrush, что и ранее --&gt;</b>

Перейти на страницу:
Комментариев (0)