EllipseGeometry 類別

定義

代表圓形或橢圓形的幾何。

public ref class EllipseGeometry sealed : System::Windows::Media::Geometry
public sealed class EllipseGeometry : System.Windows.Media.Geometry
type EllipseGeometry = class
    inherit Geometry
Public NotInheritable Class EllipseGeometry
Inherits Geometry
繼承

範例

下列範例使用兩 EllipseGeometryGeometryDrawing 物件來定義 的內容。 這個範例會產生下列輸出:

兩個橢圓形的 GeometryDrawing
兩個 EllipseGeometry 物件

using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;

namespace SDKSample
{
    public class GeometryDrawingExample : Page
    {
        public GeometryDrawingExample()
        {

            //
            // Create the Geometry to draw.
            //
            GeometryGroup ellipses = new GeometryGroup();
            ellipses.Children.Add(
                new EllipseGeometry(new Point(50,50), 45, 20)
                );
            ellipses.Children.Add(
                new EllipseGeometry(new Point(50, 50), 20, 45)
                );

            //
            // Create a GeometryDrawing.
            //
            GeometryDrawing aGeometryDrawing = new GeometryDrawing();
            aGeometryDrawing.Geometry = ellipses;

            // Paint the drawing with a gradient.
            aGeometryDrawing.Brush = 
                new LinearGradientBrush(
                    Colors.Blue, 
                    Color.FromRgb(204,204,255), 
                    new Point(0,0), 
                    new Point(1,1));

            // Outline the drawing with a solid color.
            aGeometryDrawing.Pen = new Pen(Brushes.Black, 10);

            //
            // Use a DrawingImage and an Image control
            // to display the drawing.
            //
            DrawingImage geometryImage = new DrawingImage(aGeometryDrawing);

            // Freeze the DrawingImage for performance benefits.
            geometryImage.Freeze();

            Image anImage = new Image();
            anImage.Source = geometryImage;
            anImage.Stretch = Stretch.None;
            anImage.HorizontalAlignment = HorizontalAlignment.Left;

            //
            // Place the image inside a border and
            // add it to the page.
            //
            Border exampleBorder = new Border();
            exampleBorder.Child = anImage;
            exampleBorder.BorderBrush = Brushes.Gray;
            exampleBorder.BorderThickness = new Thickness(1);
            exampleBorder.HorizontalAlignment = HorizontalAlignment.Left;
            exampleBorder.VerticalAlignment = VerticalAlignment.Top;
            exampleBorder.Margin = new Thickness(10);

            this.Margin = new Thickness(20);
            this.Background = Brushes.White;
            this.Content = exampleBorder;
        }
    }
}
<Page 
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:PresentationOptions="http://schemas.microsoft.com/winfx/2006/xaml/presentation/options" 
  xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  mc:Ignorable="PresentationOptions"
  Margin="20" Background="White">

  <Border BorderBrush="Gray" BorderThickness="1" 
    HorizontalAlignment="Left" VerticalAlignment="Top"
    Margin="10">
    <Image Stretch="None" HorizontalAlignment="Left">
      <Image.Source>
        <DrawingImage PresentationOptions:Freeze="True">
          <DrawingImage.Drawing>
          
            <GeometryDrawing>
              <GeometryDrawing.Geometry>

                <!-- Create a composite shape. -->
                <GeometryGroup>
                  <EllipseGeometry Center="50,50" RadiusX="45" RadiusY="20" />
                  <EllipseGeometry Center="50,50" RadiusX="20" RadiusY="45" />
                </GeometryGroup>
              </GeometryDrawing.Geometry>
              <GeometryDrawing.Brush>

                <!-- Paint the drawing with a gradient. -->
                <LinearGradientBrush>
                  <GradientStop Offset="0.0" Color="Blue" />
                  <GradientStop Offset="1.0" Color="#CCCCFF" />
                </LinearGradientBrush>
              </GeometryDrawing.Brush>
              <GeometryDrawing.Pen>

                <!-- Outline the drawing with a solid color. -->
                <Pen Thickness="10" Brush="Black" />
              </GeometryDrawing.Pen>
            </GeometryDrawing>
          </DrawingImage.Drawing>
        </DrawingImage>
      </Image.Source>
    </Image>
  </Border>


</Page>

備註

使用 EllipseGeometry 類別搭配 Path 專案或 GeometryDrawing 來繪製橢圓形,或搭配 Clip 的 屬性 UIElement 來定義橢圓形剪輯區域。 類別 EllipseGeometry 也有許多其他用途。 如需 的詳細資訊 EllipseGeometry ,請參閱 Geometry 概觀

EllipseGeometry 與 Ellipse 比較

類別 Ellipse 具有 FillStroke 和其他缺少的 EllipseGeometry 轉譯屬性。 類別 Ellipse 是 , FrameworkElement 因此會參與配置系統;它可以當做支援 UIElement 子系之任何元素的內容使用。

另一方面,類別 EllipseGeometry 只會定義橢圓形的幾何,而且無法自行呈現。 由於其簡單性,因此具有更廣泛的用途。

Freezable 功能

EllipseGeometry是 物件的 Freezable 類型,因此可以凍結以改善效能。 如需凍結和複製等功能的相關資訊 Freezable ,請參閱 Freezable 物件概觀

建構函式

EllipseGeometry()

初始化 EllipseGeometry 類別的新執行個體。

EllipseGeometry(Point, Double, Double)

EllipseGeometry 類別的新執行個體初始化為橢圓形,這個橢圓形具有所指定中心位置、X 半徑以及 Y 半徑。

EllipseGeometry(Point, Double, Double, Transform)

初始化 EllipseGeometry 類別的新執行個體,這個執行個體具有所指定的位置、大小以及轉換。

EllipseGeometry(Rect)

初始化 EllipseGeometry 類別的新執行個體,這個執行個體的水平直徑等於所傳遞 Rect 的寬度、垂直直徑等於所傳遞 Rect 的長度,而且中心點位置等於所傳遞 Rect 的中心。

欄位

CenterProperty

識別 Center 相依性屬性。

RadiusXProperty

識別 RadiusX 相依性屬性。

RadiusYProperty

識別 RadiusY 相依性屬性。

屬性

Bounds

取得 Rect,這個項目表示這個 EllipseGeometry 的週框方塊。 這個方法並不會視為可能透過筆劃新增的額外區域。

CanFreeze

取得值,指出是否可以將物件設為不可修改。

(繼承來源 Freezable)
Center

取得或設定 EllipseGeometry 的中心點。

DependencyObjectType

DependencyObjectType取得包裝這個實例之 CLR 型別的 。

(繼承來源 DependencyObject)
Dispatcher

取得與這個 Dispatcher 關聯的 DispatcherObject

(繼承來源 DispatcherObject)
HasAnimatedProperties

取得值,這個值表示是否有一個或多個 AnimationClock 物件與這個物件的任何一個相依性屬性相關聯。

(繼承來源 Animatable)
IsFrozen

取得值,該值表示物件目前是否可修改。

(繼承來源 Freezable)
IsSealed

取得值,這個值表示此執行個體目前是否已密封 (唯讀)。

(繼承來源 DependencyObject)
RadiusX

取得或設定 EllipseGeometry 的 X 半徑值。

RadiusY

取得或設定 EllipseGeometry 的 Y 半徑值。

Transform

取得或設定套用至 TransformGeometry 物件。

(繼承來源 Geometry)

方法

ApplyAnimationClock(DependencyProperty, AnimationClock)

AnimationClock 套用至指定的 DependencyProperty。 如果屬性已有動畫效果,即使用 SnapshotAndReplace 遞移式行為。

(繼承來源 Animatable)
ApplyAnimationClock(DependencyProperty, AnimationClock, HandoffBehavior)

AnimationClock 套用至指定的 DependencyProperty。 如果已建立屬性的動畫,則會使用指定的 HandoffBehavior

(繼承來源 Animatable)
BeginAnimation(DependencyProperty, AnimationTimeline)

將動畫套用至指定的 DependencyProperty。 呈現下一個畫面格後,就會啟動動畫。 如果指定的屬性已有動畫效果,即使用 SnapshotAndReplace 遞移式行為。

(繼承來源 Animatable)
BeginAnimation(DependencyProperty, AnimationTimeline, HandoffBehavior)

將動畫套用至指定的 DependencyProperty。 呈現下一個畫面格後,就會啟動動畫。 如果已建立指定之屬性的動畫,則會使用指定的 HandoffBehavior

(繼承來源 Animatable)
CheckAccess()

判斷呼叫的執行是否可以存取這個 DispatcherObject

(繼承來源 DispatcherObject)
ClearValue(DependencyProperty)

清除屬性的區域數值。 要清除的屬性是由 DependencyProperty 識別項所指定。

(繼承來源 DependencyObject)
ClearValue(DependencyPropertyKey)

清除唯讀屬性的區域數值。 要清除的屬性是由 DependencyPropertyKey 所指定。

(繼承來源 DependencyObject)
Clone()

建立這個 EllipseGeometry的可修改複製品,製作這個物件值的深層複本。 當複製相依性屬性時,這個方法會複製資源參考和資料繫結 (但可能無法再解析),但不會複製動畫或它們目前的值。

CloneCore(Freezable)

使用基底 (非動畫) 屬性值,將執行個體設為指定 Freezable 的複製品 (深層複製)。

(繼承來源 Freezable)
CloneCurrentValue()

建立這個 EllipseGeometry 物件的可修改複製品,製作這個物件目前值的深層複本。 不會複製資源參考、資料繫結和動畫,但是會複製其目前值。

CloneCurrentValueCore(Freezable)

使用目前的屬性值,讓執行個體成為指定之 Freezable 的可修改複本 (深層複本)。

(繼承來源 Freezable)
CoerceValue(DependencyProperty)

強制轉型所指定相依性屬性的值。 完成方式是叫用存在於呼叫 DependencyObject 之相依性屬性的屬性中繼資料中所指定的任何 CoerceValueCallback 函式。

(繼承來源 DependencyObject)
CreateInstance()

初始化 Freezable 類別的新執行個體。

(繼承來源 Freezable)
CreateInstanceCore()

在衍生類別中實作時,建立 Freezable 衍生類別的新執行個體。

(繼承來源 Freezable)
Equals(Object)

判斷提供的 DependencyObject 和目前的 DependencyObject 是否相等。

(繼承來源 DependencyObject)
FillContains(Geometry)

表示目前幾何是否完整包含指定的 Geometry

(繼承來源 Geometry)
FillContains(Geometry, Double, ToleranceType)

在指定的邊際誤差下,表示目前幾何是否包含指定的 Geometry

(繼承來源 Geometry)
FillContains(Point)

表示幾何是否包含指定的 Point

(繼承來源 Geometry)
FillContains(Point, Double, ToleranceType)

在指定的邊際誤差下,表示幾何是否包含指定的 Point

(繼承來源 Geometry)
FillContainsWithDetail(Geometry)

傳回值,這個值描述目前幾何與所指定幾何的交集。

(繼承來源 Geometry)
FillContainsWithDetail(Geometry, Double, ToleranceType)

傳回值,這個值描述在指定的邊際誤差下,目前幾何與所指定幾何的交集。

(繼承來源 Geometry)
Freeze()

將目前的物件設為不可修改,並將其 IsFrozen 屬性設定為 true

(繼承來源 Freezable)
FreezeCore(Boolean)

將這個 Animatable 物件設定為不可修改,或決定是否可以將它設定為不可修改。

(繼承來源 Animatable)
GetAnimationBaseValue(DependencyProperty)

傳回指定之 DependencyProperty 的非動畫實值。

(繼承來源 Animatable)
GetArea()

取得 Geometry 物件的填滿區域。

(繼承來源 Geometry)
GetArea(Double, ToleranceType)

取得這個 EllipseGeometry 的區域。

GetAsFrozen()

使用基底 (非動畫) 屬性值,建立 Freezable 的凍結複本。 因為複本已凍結,所以會以傳址方式複製任何凍結子物件。

(繼承來源 Freezable)
GetAsFrozenCore(Freezable)

使用基底 (非動畫) 屬性值,將執行個體設為指定 Freezable 的凍結複本。

(繼承來源 Freezable)
GetCurrentValueAsFrozen()

使用目前屬性值,建立 Freezable 的凍結複本。 因為複本已凍結,所以會以傳址方式複製任何凍結子物件。

(繼承來源 Freezable)
GetCurrentValueAsFrozenCore(Freezable)

將目前執行個體設為所指定 Freezable 的凍結複本。 如果物件具有動畫相依性屬性,則會複製其目前的動畫值。

(繼承來源 Freezable)
GetFlattenedPathGeometry()

取得 PathGeometry,此為 Geometry 物件的多邊形近似值。

(繼承來源 Geometry)
GetFlattenedPathGeometry(Double, ToleranceType)

在指定的容許誤差內取得 PathGeometry,這是 Geometry 物件的多邊形近似值。

(繼承來源 Geometry)
GetHashCode()

取得這個 DependencyObject 的雜湊碼。

(繼承來源 DependencyObject)
GetLocalValueEnumerator()

建立特定的列舉值,以判斷哪些相依性屬性在此 DependencyObject 上具有本機設定的值。

(繼承來源 DependencyObject)
GetOutlinedPathGeometry()

取得 PathGeometry,此為 Geometry 填滿區域的簡單外框。

(繼承來源 Geometry)
GetOutlinedPathGeometry(Double, ToleranceType)

在指定的容許誤差內,取得 PathGeometry,這是 Geometry 之填滿區域的簡單外框。

(繼承來源 Geometry)
GetRenderBounds(Pen)

傳回與軸對齊的矩形,這個矩形正好能夠容納利用 Pen 加上外框後的幾何。

(繼承來源 Geometry)
GetRenderBounds(Pen, Double, ToleranceType)

傳回與軸對齊的矩形,這個矩形能夠在指定的容錯因數下,正好能夠容納利用指定的 Pen 加上外框後的幾何。

(繼承來源 Geometry)
GetType()

取得目前執行個體的 Type

(繼承來源 Object)
GetValue(DependencyProperty)

傳回 DependencyObject 的這個執行個體上之相依性屬性的目前有效值。

(繼承來源 DependencyObject)
GetWidenedPathGeometry(Pen)

取得 PathGeometry,此為 Geometry 上之筆觸所定義的形狀,筆觸位於指定之 Pen 所產生的項目上。

(繼承來源 Geometry)
GetWidenedPathGeometry(Pen, Double, ToleranceType)

取得 PathGeometry,這個圖案是由 Geometry 上的筆劃定義,而該筆劃是由指定的 Pen 在指定的容錯因數下產生。

(繼承來源 Geometry)
InvalidateProperty(DependencyProperty)

重新評估指定相依性屬性的有效值。

(繼承來源 DependencyObject)
IsEmpty()

判斷這個 EllipseGeometry 物件是否空白。

MayHaveCurves()

判斷這個 EllipseGeometry 物件是否具有弧形片段。

MemberwiseClone()

建立目前 Object 的淺層複製。

(繼承來源 Object)
OnChanged()

目前的 Freezable 物件遭到修改時進行呼叫。

(繼承來源 Freezable)
OnFreezablePropertyChanged(DependencyObject, DependencyObject)

確定已為剛剛設定的 DependencyObjectType 資料成員,建立適當的內容指標。

(繼承來源 Freezable)
OnFreezablePropertyChanged(DependencyObject, DependencyObject, DependencyProperty)

此成員支援Windows Presentation Foundation (WPF) 基礎結構,而且不適合直接從程式碼使用。

(繼承來源 Freezable)
OnPropertyChanged(DependencyPropertyChangedEventArgs)

覆寫 OnPropertyChanged(DependencyPropertyChangedEventArgs)DependencyObject 實作也可以叫用任何 Changed 處理常式,以回應類型 Freezable 的變更相依性屬性。

(繼承來源 Freezable)
ReadLocalValue(DependencyProperty)

傳回相依性屬性的區域值 (如果存在)。

(繼承來源 DependencyObject)
ReadPreamble()

確定 Freezable 是從有效的執行緒進行存取。 如果 API 會讀取非相依性屬性的資料成員,則 Freezable 的繼承者必須在該 API 的開頭呼叫這個方法。

(繼承來源 Freezable)
SetCurrentValue(DependencyProperty, Object)

設定相依性屬性的值,而不需要變更其值來源。

(繼承來源 DependencyObject)
SetValue(DependencyProperty, Object)

設定相依性屬性的區域值 (由相依性屬性的識別碼所指定)。

(繼承來源 DependencyObject)
SetValue(DependencyPropertyKey, Object)

設定唯讀相依性屬性的區域數值 (由相依性屬性的 DependencyPropertyKey 識別項所指定)。

(繼承來源 DependencyObject)
ShouldSerializeProperty(DependencyProperty)

傳回值,這個值表示序列化程序是否應該序列化所提供相依性屬性的值。

(繼承來源 DependencyObject)
ShouldSerializeTransform()

取得值,這個值表示是否應該序列化 Transform 屬性的值。

(繼承來源 Geometry)
StrokeContains(Pen, Point)

判斷指定的 Point 是否包含於筆劃中,而這個筆劃是將指定的 Pen 套用至幾何後而產生。

(繼承來源 Geometry)
StrokeContains(Pen, Point, Double, ToleranceType)

在指定的邊際誤差下,判斷指定的 Point 是否包含於筆劃中,而這個筆劃是將指定的 Pen 套用至幾何後而產生。

(繼承來源 Geometry)
StrokeContainsWithDetail(Pen, Geometry)

傳回值,這個值描述所指定 Geometry 與將指定的 Pen 套用至目前幾何後而建立之筆劃的交集。

(繼承來源 Geometry)
StrokeContainsWithDetail(Pen, Geometry, Double, ToleranceType)

取得值,這個值描述在指定的邊際誤差下,所指定 Geometry 與將指定的 Pen 套用至目前幾何後而建立之筆劃的交集。

(繼承來源 Geometry)
ToString()

根據目前的文化,建立物件的字串表示。

(繼承來源 Geometry)
ToString(IFormatProvider)

使用指定的文化特性特定格式資訊,建立物件的字串表示。

(繼承來源 Geometry)
VerifyAccess()

請強制執行可以存取這個 DispatcherObject 的呼叫執行緒。

(繼承來源 DispatcherObject)
WritePostscript()

引發 FreezableChanged 事件,並叫用其 OnChanged() 方法。 在任何 API 修改未以相依性屬性儲存的類別成員之後,衍生自 Freezable 的類別應該在 API 的結尾呼叫這個方法。

(繼承來源 Freezable)
WritePreamble()

確認 Freezable 未凍結,而且是從有效的執行緒內容進行存取。 在任何 API 將資料寫入至非相依性屬性的資料成員之前,Freezable 繼承者應該在 API 的開頭呼叫這個方法。

(繼承來源 Freezable)

事件

Changed

發生於 Freezable 或所含的物件遭到修改時。

(繼承來源 Freezable)

明確介面實作

IFormattable.ToString(String, IFormatProvider)

使用指定的格式,格式化目前執行個體的值。

(繼承來源 Geometry)

適用於

另請參閱