- Работа с графикой
- Фигуры
- Ellipse
- Rectangle
- Polygon
- Polyline
- Настройка контура
- Программное рисование
- Ellipse Geometry Класс
- Определение
- Примеры
- Комментарии
- EllipseGeometry по сравнению с эллипсом EllipseGeometry Compared to Ellipse
- Возможности объектов Freezable Freezable Features
- Конструкторы
- Свойства
- Методы
- События
- Явные реализации интерфейса
Работа с графикой
Фигуры
Одним из способов построения двухмерной графики в окне — это использование фигур. Фигуры фактически являются обычными элементами как например кнопка или текстовое поле. К фигурам относят такие элементы как Polygon (Многоугольник), Ellipse (овал), Rectangle (прямоугольник), Line (обычная линия), Polyline (несколько связанных линий). Все они наследуются от абстрактного базового класса System.Windows.Shapes.Shape :
От базового класса они наследуют ряд общих свойств:
Fill заполняет фон фигуры с помощью кисти — аналогичен свойству Background у прочих элементов
Stroke задает кисть, которая отрисовывает границу фигуры — аналогичен свойству BorderBrush у прочих элементов
StrokeThikness задает толщину границы фигуры — аналогичен свойству BorderThikness у прочих элементов
StrokeStartLineCap и StrokeEndLineCap задают для незамкнутых фигур (Line) контур в начале и в конце линии соответственно
StrokeDashArray задает границу фигуры в виде штриховки, создавая эффект пунктира
StrokeDashOffset задает расстояние до начала штриха
StrokeDashCap задает форму штрихов
Ellipse
Ellipse представляет овал:
При одинаковой ширине и высоту получается круг:
Rectangle
Rectangle представляет прямоугольник::
С помощью свойств RadiusX и RadiusY можно округлить углы прямоугольника:
Line представляет простую линию. Для создания линии надо указать координаты в ее свойствах X1, Y1, X2 и Y2. При этом надо учитывать, что началом координатной системы является верхний левый угол:
Polygon
Polygon представляет многоугольник. С помощью коллекции Points элемент устанавливает набор точек — объектов типа Point, которые последовательно соединяются линиями, причем последня точка соединяется с первой:
В данном случае у нас три точки (50, 150), (150, 50) и (250, 150), которые образуют треугольник.
Polyline
Polyline представляет набор точек, соединенных линиями. В этом плане данный элемент похож на Polygon за тем исключением, что первая и последняя точка не соединяются:
Настройка контура
С помощью ряда свойств мы можем настроить отображение контура. Например:
Цвет самого контура определяется с помощью свойства Stroke , а его толщина — с помощью StrokeThickness .
StrokeDashArray устанавливает длину штрихов вместе с отступами. Например, StrokeDashArray=»4 2″ устанавливает длину штриха в 4 единицы, а последующего отступа в 2 единицы. И эти значения будут повторяться по всему контуру. При другой установке, например, StrokeDashArray=»1 2 3″ уже задается два штриха. Первый штрих имеет длину в 1 единицу, а второй — в 3 единицы и между ними расстояие в 2 единицы. И так вы можем настроить количество штрихов и расстояний между ними.
StrokeDashCap задает форму на концах штрихов и может принимать следующие значения:
Flat : стандартные штрихи с плоскими окончаниями
Square : штрихи с прямоугольными окончаниями
Round : штрихи с округлыми окончаниями
Triangle : штрихи с окончаниями в виде треугольников
Программное рисование
Создание фигур программным образом осуществляется так же, как и создаются и добавляются все остальные элементы:
Нарисуем, к примеру, координатную плоскость:
Ellipse Geometry Класс
Определение
Представляет геометрию окружности или эллипса. Represents the geometry of a circle or ellipse.
Примеры
В следующем примере EllipseGeometry для определения содержимого объекта используются два объекта GeometryDrawing . The following example uses two EllipseGeometry objects to define the contents of a GeometryDrawing. В этом примере выводятся следующие данные: This example produces the following output:
Два объекта EllipseGeometry Two EllipseGeometry objects
Комментарии
Используйте EllipseGeometry класс с Path элементом или GeometryDrawing для рисования эллипса или со Clip свойством объекта UIElement для определения области эллиптического фрагмента. Use the EllipseGeometry class with a Path element or a GeometryDrawing to draw an ellipse, or with the Clip property of a UIElement to define an elliptical clip region. EllipseGeometryКласс также имеет много других целей. The EllipseGeometry class also has many other uses. Дополнительные сведения о см EllipseGeometry . в разделе Общие сведения о геометрии. For more information about EllipseGeometry, see Geometry Overview.
EllipseGeometry по сравнению с эллипсом EllipseGeometry Compared to Ellipse
EllipseКласс имеет Fill , Stroke и другие свойства отрисовки, которые EllipseGeometry отсутствуют. The Ellipse class has a Fill, Stroke, and other rendering properties that EllipseGeometry lacks. EllipseКласс является и, FrameworkElement следовательно, участвует в системе макета. его можно использовать в качестве содержимого любого элемента, который поддерживает UIElement дочерние элементы. The Ellipse class is a FrameworkElement and therefore participates in the layout system; it can be used as the content of any element that supports UIElement children.
EllipseGeometryКласс, с другой стороны, просто определяет геометрию эллипса и не может визуализировать сам себя. The EllipseGeometry class, on the other hand, simply defines the geometry of an ellipse, and cannot render itself. Из-за простоты он имеет более широкий спектр применений. Because of its simplicity, it has a wider range of uses.
Возможности объектов Freezable Freezable Features
Объект EllipseGeometry является типом Freezable объекта и, следовательно, может быть заморожен для повышения производительности. An EllipseGeometry is a type of Freezable object and therefore can be frozen to improve performance. Дополнительные сведения о Freezable функциях, таких как замораживание и клонирование, см. в разделе Общие сведения об объектах Freezable. For information about Freezable features, such as freezing and cloning, see Freezable Objects Overview.
Конструкторы
Инициализирует новый экземпляр класса EllipseGeometry. Initializes a new instance of the EllipseGeometry class.
Инициализирует новый экземпляр класса EllipseGeometry как эллипс с заданным местоположением центра и радиусами x и y. Initializes a new instance of the EllipseGeometry class as an ellipse that has a specified center location, x radius, and y radius.
Инициализирует новый экземпляр класса EllipseGeometry с заданными местоположением, размером и преобразованием. Initializes a new instance of the EllipseGeometry class that has the specified position, size, and transformation.
Инициализирует новый экземпляр класса EllipseGeometry, горизонтальный диаметр которого равен ширине переданного Rect, вертикальный — длине переданного Rect, а центральная точка находится в центре этого Rect. Initializes a new instance of the EllipseGeometry class that has a horizontal diameter equal to the width of the passed Rect, a vertical diameter equal to the length of the passed Rect, and a center point location equal to the center of the passed Rect.
Идентифицирует свойство зависимостей Center. Identifies the Center dependency property.
Идентифицирует свойство зависимостей RadiusX. Identifies the RadiusX dependency property.
Идентифицирует свойство зависимостей RadiusY. Identifies the RadiusY dependency property.
Свойства
Получает объект Rect, который представляет ограничивающий прямоугольник данного EllipseGeometry. Gets a Rect that represents the bounding box of this EllipseGeometry. Этот метод не учитывает дополнительную область, потенциально добавленную обводкой. This method does not consider the extra area potentially added by a stroke.
Возвращает значение, которое указывает, можно ли сделать объект неизменяемым. Gets a value that indicates whether the object can be made unmodifiable.
(Унаследовано от Freezable)
Возвращает или задает центральную точку EllipseGeometry. Gets or sets the center point of the EllipseGeometry.
Возвращает объект DependencyObjectType , который заключает в оболочку тип CLR данного экземпляра. Gets the DependencyObjectType that wraps the CLR type of this instance.
(Унаследовано от DependencyObject)
Возвращает объект Dispatcher, с которым связан этот объект DispatcherObject. Gets the Dispatcher this DispatcherObject is associated with.
(Унаследовано от DispatcherObject)
Возвращает значение, которое указывает, сопоставлены ли один или несколько объектов AnimationClock любому из свойств зависимостей этого объекта. Gets a value that indicates whether one or more AnimationClock objects is associated with any of this object’s dependency properties.
(Унаследовано от Animatable)
Получает значение, указывающее, доступен ли объект для изменения в настоящее время. Gets a value that indicates whether the object is currently modifiable.
(Унаследовано от Freezable)
Получает значение, указывающее, является ли этот экземпляр в данный момент запечатанным (доступным только для чтения). Gets a value that indicates whether this instance is currently sealed (read-only).
(Унаследовано от DependencyObject)
Получает или задает значение X-радиуса EllipseGeometry. Gets or sets the x-radius value of the EllipseGeometry.
Получает или задает значение y-радиуса EllipseGeometry. Gets or sets the y-radius value of the EllipseGeometry.
Получает или задает объект Transform, примененный к Geometry. Gets or sets the Transform object applied to a Geometry.
(Унаследовано от Geometry)
Методы
Применяет AnimationClock к заданному DependencyProperty. Applies an AnimationClock to the specified DependencyProperty. Если свойство уже анимировано, используется эстафетное поведение SnapshotAndReplace. If the property is already animated, the SnapshotAndReplace handoff behavior is used.
(Унаследовано от Animatable)
Применяет AnimationClock к заданному DependencyProperty. Applies an AnimationClock to the specified DependencyProperty. Если свойство уже является анимированным, используется указанное поведение HandoffBehavior. If the property is already animated, the specified HandoffBehavior is used.
(Унаследовано от Animatable)
Применяет анимацию к указанному DependencyProperty. Applies an animation to the specified DependencyProperty. Анимация начинается при отрисовке следующего кадра. The animation is started when the next frame is rendered. Если указанное свойство уже анимировано, используется поведение перемещения SnapshotAndReplace. If the specified property is already animated, the SnapshotAndReplace handoff behavior is used.
(Унаследовано от Animatable)
Применяет анимацию к указанному DependencyProperty. Applies an animation to the specified DependencyProperty. Анимация начинается при отрисовке следующего кадра. The animation is started when the next frame is rendered. Если указанное свойство уже является анимированным, используется указанное поведение HandoffBehavior. If the specified property is already animated, the specified HandoffBehavior is used.
(Унаследовано от Animatable)
Определяет, имеет ли вызывающий поток доступ к этому DispatcherObject. Determines whether the calling thread has access to this DispatcherObject.
(Унаследовано от DispatcherObject)
Очищает локальное значение свойства. Clears the local value of a property. Очищаемое свойство задается идентификатором DependencyProperty. The property to be cleared is specified by a DependencyProperty identifier.
(Унаследовано от DependencyObject)
Очищает локальное значение доступного только для чтения свойства. Clears the local value of a read-only property. Очищаемое свойство задается ключом DependencyPropertyKey. The property to be cleared is specified by a DependencyPropertyKey.
(Унаследовано от DependencyObject)
Создает изменяемый клон данного объекта EllipseGeometry, делая глубокие копии значений этого объекта. Creates a modifiable clone of this EllipseGeometry, making deep copies of this object’s values. При копировании свойств зависимостей этот метод копирует ссылки на ресурсы и привязки данных (которые могут уже не быть разрешимыми), но не копирует анимации и их текущие значения. When copying dependency properties, this method copies resource references and data bindings (but they might no longer resolve) but not animations or their current values.
Делает экземпляр клоном (глубокой копией) указанного объекта Freezable, используя базовые (без анимации) значения свойств. Makes the instance a clone (deep copy) of the specified Freezable using base (non-animated) property values.
(Унаследовано от Freezable)
Создает модифицируемый клон данного объекта EllipseGeometry, делая глубокие копии текущих значений этого объекта. Creates a modifiable clone of this EllipseGeometry object, making deep copies of this object’s current values. Ссылки на ресурсы, привязки данных и анимации не копируются, но копируются их текущие значения. Resource references, data bindings, and animations are not copied, but their current values are.
Делает экземпляр изменяемым клоном (глубокой копией) указанного объекта Freezable с использованием текущих значений свойств. Makes the instance a modifiable clone (deep copy) of the specified Freezable using current property values.
(Унаследовано от Freezable)
Приводит значение указанного свойства зависимостей. Coerces the value of the specified dependency property. Это осуществляется путем вызова какой-либо функции CoerceValueCallback, указанной в метаданных свойства зависимостей, которое существует в вызывающем объекте DependencyObject. This is accomplished by invoking any CoerceValueCallback function specified in property metadata for the dependency property as it exists on the calling DependencyObject.
(Унаследовано от DependencyObject)
Инициализирует новый экземпляр класса Freezable. Initializes a new instance of the Freezable class.
(Унаследовано от Freezable)
Если реализуется в производном классе, создает новый экземпляр производного класса Freezable. When implemented in a derived class, creates a new instance of the Freezable derived class.
(Унаследовано от Freezable)
Определяет, является ли указанный DependencyObject эквивалентом текущего DependencyObject. Determines whether a provided DependencyObject is equivalent to the current DependencyObject.
(Унаследовано от DependencyObject)
Указывает, содержится ли заданный объект Geometry целиком в текущей геометрии. Indicates whether the current geometry completely contains the specified Geometry.
(Унаследовано от Geometry)
Указывает, содержит ли текущая геометрия заданный объект Geometry с учетом заданного предела погрешности. Indicates whether the current geometry contains the specified Geometry, given the specified margin of error.
(Унаследовано от Geometry)
Определяет, содержит ли данная геометрия заданный объект Point. Indicates whether the geometry contains the specified Point.
(Унаследовано от Geometry)
Указывает, содержит ли данная геометрия заданный объект Point с учетом заданного предела погрешности. Indicates whether the geometry contains the specified Point, given the specified margin of error.
(Унаследовано от Geometry)
Возвращает значение, описывающее пересечение текущей и заданной геометрий. Returns a value that describes the intersection between the current geometry and the specified geometry.
(Унаследовано от Geometry)
Возвращает значение, описывающее пересечение текущей и заданной геометрий с учетом заданного предела погрешности. Returns a value that describes the intersection between the current geometry and the specified geometry, given the specified margin of error.
(Унаследовано от Geometry)
Делает текущий объект неизменяемым и присваивает его свойству IsFrozen значение true . Makes the current object unmodifiable and sets its IsFrozen property to true .
(Унаследовано от Freezable)
Делает данный объект Animatable неизменяемым или определяет, может ли он быть сделан неизменяемым. Makes this Animatable object unmodifiable or determines whether it can be made unmodifiable.
(Унаследовано от Animatable)
Возвращает не анимированное значение указанного объекта DependencyProperty. Returns the non-animated value of the specified DependencyProperty.
(Унаследовано от Animatable)
Получает заполненную область данного объекта Geometry. Gets the area of the filled region of the Geometry object.
(Унаследовано от Geometry)
Получает область данного EllipseGeometry. Gets the area of this EllipseGeometry.
Создает фиксированную копию объекта Freezable, используя базовые (не анимационные) значения свойств. Creates a frozen copy of the Freezable, using base (non-animated) property values. Так как копия является фиксированной, копируются только ссылки на фиксированные вложенные объекты. Because the copy is frozen, any frozen sub-objects are copied by reference.
(Унаследовано от Freezable)
Делает экземпляр зафиксированной копией указанного Freezable, используя базовые (без анимации) значения свойств. Makes the instance a frozen clone of the specified Freezable using base (non-animated) property values.
(Унаследовано от Freezable)
Создает фиксированную копию объекта Freezable с использованием текущих значений свойств. Creates a frozen copy of the Freezable using current property values. Так как копия является фиксированной, копируются только ссылки на фиксированные вложенные объекты. Because the copy is frozen, any frozen sub-objects are copied by reference.
(Унаследовано от Freezable)
Создает текущий экземпляр замороженной копии указанного объекта Freezable. Makes the current instance a frozen clone of the specified Freezable. Если объект имеет анимированные свойства зависимостей, копируются их текущие анимированные значения. If the object has animated dependency properties, their current animated values are copied.
(Унаследовано от Freezable)
Получает объект PathGeometry, являющийся кусочно-линейной аппроксимацией данного объекта Geometry. Gets a PathGeometry that is a polygonal approximation of the Geometry object.
(Унаследовано от Geometry)
Получает объект PathGeometry в пределах заданного допуска, являющийся кусочно-линейной аппроксимацией данного объекта Geometry. Gets a PathGeometry, within the specified tolerance, that is a polygonal approximation of the Geometry object.
(Унаследовано от Geometry)
Возвращает хэш-код для данного объекта DependencyObject. Gets a hash code for this DependencyObject.
(Унаследовано от DependencyObject)
Создает специализированный перечислитель для определения свойств зависимостей, которые локально установили значения для данного DependencyObject. Creates a specialized enumerator for determining which dependency properties have locally set values on this DependencyObject.
(Унаследовано от DependencyObject)
Получает объект PathGeometry в пределах заданного допуска, являющийся упрощенным контуром заполненной области данного объекта Geometry. Gets a PathGeometry that is a simplified outline of the filled region of the Geometry.
(Унаследовано от Geometry)
Получает объект PathGeometry в пределах заданного допуска, являющийся упрощенным контуром заполненной области данного объекта Geometry. Gets a PathGeometry, within the specified tolerance, that is a simplified outline of the filled region of the Geometry.
(Унаследовано от Geometry)
Возвращает выровненный по осям прямоугольник, достаточно большой для того, чтобы вместить данную геометрию, после ее обведения заданным Pen. Returns an axis-aligned rectangle that is exactly large enough to contain the geometry after it has been outlined with the specified Pen.
(Унаследовано от Geometry)
Возвращает выровненный по осям прямоугольник, достаточно большой для того, чтобы вместить данную геометрию, после ее обведения заданным Pen с использованием указанного коэффициента допуска. Returns an axis-aligned rectangle that is exactly large enough to contain the geometry after it has been outlined with the specified Pen, given the specified tolerance factor.
(Унаследовано от Geometry)
Возвращает объект Type для текущего экземпляра. Gets the Type of the current instance.
(Унаследовано от Object)
Возвращает текущее действующее значение свойства зависимостей в этом экземпляре DependencyObject. Returns the current effective value of a dependency property on this instance of a DependencyObject.
(Унаследовано от DependencyObject)
Получает PathGeometry, представляющий собой фигуру, определенную обводкой объекта Geometry, созданной заданным объектом Pen, с учетом заданного коэффициента допуска. Gets a PathGeometry that is the shape defined by the stroke on the Geometry produced by the specified Pen.
(Унаследовано от Geometry)
Получает PathGeometry, представляющий собой фигуру, определенную обводкой объекта Geometry, созданной заданным объектом Pen, с учетом заданного коэффициента допуска. Gets a PathGeometry that is the shape defined by the stroke on the Geometry produced by the specified Pen, given the specified tolerance factor.
(Унаследовано от Geometry)
Повторно вычисляет действующее значение для указанного свойства зависимостей. Re-evaluates the effective value for the specified dependency property.
(Унаследовано от DependencyObject)
Определяет, является ли данный объект EllipseGeometry пустым. Determines whether this EllipseGeometry object is empty.
Определяет, может ли данный объект EllipseGeometry иметь криволинейные сегменты. Determines whether this EllipseGeometry object can have curved segments.
Создает неполную копию текущего объекта Object. Creates a shallow copy of the current Object.
(Унаследовано от Object)
Вызывается при изменении текущего объекта Freezable. Called when the current Freezable object is modified.
(Унаследовано от Freezable)
Обеспечивает создание соответствующих указателей контекста для элемента данных типа DependencyObjectType, который был только что задан. Ensures that appropriate context pointers are established for a DependencyObjectType data member that has just been set.
(Унаследовано от Freezable)
Этот элемент поддерживает инфраструктуру Windows Presentation Foundation (WPF) и не предназначен для непосредственного использования из кода. This member supports the Windows Presentation Foundation (WPF) infrastructure and is not intended to be used directly from your code.
(Унаследовано от Freezable)
Переопределяет реализацию DependencyObject для OnPropertyChanged(DependencyPropertyChangedEventArgs), чтобы также вызвать любой обработчик Changed в ответ на изменение свойства зависимостей типа Freezable. Overrides the DependencyObject implementation of OnPropertyChanged(DependencyPropertyChangedEventArgs) to also invoke any Changed handlers in response to a changing dependency property of type Freezable.
(Унаследовано от Freezable)
Возвращает локальное значение свойства зависимостей, если таковое существует. Returns the local value of a dependency property, if it exists.
(Унаследовано от DependencyObject)
Обеспечивает доступ к Freezable из допустимого потока. Ensures that the Freezable is being accessed from a valid thread. Наследники объекта Freezable должны вызывать данный метод в начале любого API, который считывает элементы данных, не являющиеся свойствами зависимостей. Inheritors of Freezable must call this method at the beginning of any API that reads data members that are not dependency properties.
(Унаследовано от Freezable)
Задает значение свойства зависимостей, не меняя источник значения. Sets the value of a dependency property without changing its value source.
(Унаследовано от DependencyObject)
Задает локальное значение свойства зависимостей, указанного идентификатором этого свойства. Sets the local value of a dependency property, specified by its dependency property identifier.
(Унаследовано от DependencyObject)
Задает локальное значение свойства зависимости только для чтения, определяемое идентификатором DependencyPropertyKey свойства зависимостей. Sets the local value of a read-only dependency property, specified by the DependencyPropertyKey identifier of the dependency property.
(Унаследовано от DependencyObject)
Возвращает значение, которое указывает, следует ли процессам сериализации выполнять сериализацию значения для предоставленного свойства зависимостей. Returns a value that indicates whether serialization processes should serialize the value for the provided dependency property.
(Унаследовано от DependencyObject)
Получает значение, которое указывает, должно ли значение свойства Transform быть сериализовано. Gets a value that indicates whether the value of the Transform property should be serialized.
(Унаследовано от Geometry)
Определяет, содержится ли заданный объект Point в обводке, полученной путем применения заданного Pen к данной геометрии. Determines whether the specified Point is contained in the stroke produced by applying the specified Pen to the geometry.
(Унаследовано от Geometry)
Определяет, содержится ли заданный объект Point в обводке, полученной путем применения заданного Pen к данной геометрии, с учетом заданного предела погрешности. Determines whether the specified Point is contained in the stroke produced by applying the specified Pen to the geometry, given the specified margin of error.
(Унаследовано от Geometry)
Возвращает значение, описывающее пересечение между заданным объектом Geometry и обводкой, созданной путем применения заданного объекта Pen к текущей геометрии. Returns a value that describes the intersection between the specified Geometry and the stroke created by applying the specified Pen to the current geometry.
(Унаследовано от Geometry)
Получает значение, описывающее пересечение между заданным объектом Geometry и обводкой, созданной путем применения заданного объекта Pen к текущей геометрии с учетом заданного предела погрешности. Gets a value that describes the intersection between the specified Geometry and the stroke created by applying the specified Pen to the current geometry, given the specified margin of error.
(Унаследовано от Geometry)
Создает строковое представление объекта на базе региональных параметров. Creates a string representation of the object based on the current culture.
(Унаследовано от Geometry)
Создает строковое представление данного объекта с учетом сведений о форматировании, связанных с определенным языком и региональными параметрами. Creates a string representation of the object using the specified culture-specific formatting information.
(Унаследовано от Geometry)
Обеспечивает наличие у вызывающего потока доступ к этому DispatcherObject. Enforces that the calling thread has access to this DispatcherObject.
(Унаследовано от DispatcherObject)
Вызывает событие Changed для объекта Freezable и вызывает его метод OnChanged(). Raises the Changed event for the Freezable and invokes its OnChanged() method. Классы, производные от Freezable, должны вызывать этот метод в конце любого API, который изменяет члены класса, не сохраненные в виде свойств зависимостей. Classes that derive from Freezable should call this method at the end of any API that modifies class members that are not stored as dependency properties.
(Унаследовано от Freezable)
Проверяет, что объект Freezable не заморожен и доступ к нему осуществляется из допустимого контекста потока. Verifies that the Freezable is not frozen and that it is being accessed from a valid threading context. Наследники объекта Freezable должны вызывать данный метод в начале любого API, который выполняет запись в элементах данных, не являющихся свойствами зависимостей. Freezable inheritors should call this method at the beginning of any API that writes to data members that are not dependency properties.
(Унаследовано от Freezable)
События
Происходит, когда изменяется класс Freezable или объект, который входит в его состав. Occurs when the Freezable or an object it contains is modified.
(Унаследовано от Freezable)
Явные реализации интерфейса
Форматирует значение текущего экземпляра с использованием указанного формата. Formats the value of the current instance using the specified format.