Floater 类
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
提供一个内联级别的流内容元素,该元素用于承载一个浮标。 “浮标”显示与 FlowDocument 中的主内容流平行的图像和其他内容。
public ref class Floater : System::Windows::Documents::AnchoredBlock
public class Floater : System.Windows.Documents.AnchoredBlock
type Floater = class
inherit AnchoredBlock
Public Class Floater
Inherits AnchoredBlock
- 继承
示例
以下示例定义FlowDocument同时包含 和 Figure 元素的 Floater 。
<FlowDocumentReader>
<FlowDocument
ColumnWidth="400"
IsOptimalParagraphEnabled="True" IsHyphenationEnabled="True"
>
<Section FontSize="12">
<Paragraph>
<Bold>Neptune</Bold> (planet), major planet in the solar system, eighth planet
from the Sun and fourth largest in diameter. Neptune maintains an almost constant
distance, about 4,490 million km (about 2,790 million mi), from the Sun. Neptune
revolves outside the orbit of Uranus and for most of its orbit moves inside the
elliptical path of the outermost planet Pluto (see Solar System). Every 248 years,
Pluto’s elliptical orbit brings the planet inside Neptune’s nearly circular orbit
for about 20 years, temporarily making Neptune the farthest planet from the Sun.
The last time Pluto’s orbit brought it inside Neptune’s orbit was in 1979. In
1999 Pluto’s orbit carried it back outside Neptune’s orbit.
<!-- This Figure uses relative measurements for width and height. -->
<Figure
Width="0.25" Height="0.1" Background="GhostWhite"
HorizontalAnchor="PageLeft"
HorizontalOffset="100" VerticalOffset="20"
>
<Paragraph
FontStyle="Italic" TextAlignment="Left"
Background="Beige" Foreground="DarkGreen"
>
Neptune has 72 times Earth's volume...
</Paragraph>
</Figure>
<!-- This Floater uses relative measurements for width. -->
<Floater
Background="GhostWhite"
Width="0.4" HorizontalAlignment="Left"
>
<Table CellSpacing="5">
<Table.Columns>
<TableColumn Width="155"/>
<TableColumn Width="130"/>
</Table.Columns>
<TableRowGroup>
<TableRow>
<TableCell ColumnSpan="3">
<Paragraph>Neptune Stats</Paragraph>
</TableCell>
</TableRow>
<TableRow Background="LightGoldenrodYellow" FontSize="12">
<TableCell>
<Paragraph FontWeight="Bold">Mean Distance from Sun</Paragraph>
</TableCell>
<TableCell>
<Paragraph>4,504,000,000 km</Paragraph>
</TableCell>
</TableRow>
<TableRow FontSize="12" Background="LightGray">
<TableCell>
<Paragraph FontWeight="Bold">Mean Diameter</Paragraph>
</TableCell>
<TableCell>
<Paragraph>49,532 km</Paragraph>
</TableCell>
</TableRow>
<TableRow Background="LightGoldenrodYellow" FontSize="12">
<TableCell>
<Paragraph FontWeight="Bold">Approximate Mass</Paragraph>
</TableCell>
<TableCell>
<Paragraph>1.0247e26 kg</Paragraph>
</TableCell>
</TableRow>
<TableRow>
<TableCell ColumnSpan="4">
<Paragraph FontSize="10" FontStyle="Italic">
Information from the
<Hyperlink
NavigateUri="http://encarta.msn.com/encnet/refpages/artcenter.aspx"
>Encarta</Hyperlink>
web site.
</Paragraph>
</TableCell>
</TableRow>
</TableRowGroup>
</Table>
</Floater>
</Paragraph>
<Paragraph>
Astronomers believe Neptune has an inner rocky core that is surrounded by a vast
ocean of water mixed with rocky material. From the inner core, this ocean extends
upward until it meets a gaseous atmosphere of hydrogen, helium, and trace amounts
of methane. Neptune has four rings and 11 known moons. Even though Neptune's volume
is 72 times Earth’s volume, its mass is only 17.15 times Earth’s mass. Because of
its size, scientists classify Neptune—along with Jupiter, Saturn, and Uranus—as
one of the giant or Jovian planets (so-called because they resemble Jupiter).
</Paragraph>
<Paragraph>
<Figure
Width="140" Height="50"
Background="GhostWhite" TextAlignment="Left"
HorizontalAnchor="PageCenter" WrapDirection="Both"
>
<Paragraph FontStyle="Italic" Background="Beige" Foreground="DarkGreen" >
Neptune has an orbital period of ~20 years...
</Paragraph>
</Figure>
Mathematical theories of astronomy led to the discovery of Neptune. To account for
wobbles in the orbit of the planet Uranus, British astronomer John Couch Adams and
French astronomer Urbain Jean Joseph Leverrier independently calculated the existence
and position of a new planet in 1845 and 1846, respectively. They theorized that the
gravitational attraction of this planet for Uranus was causing the wobbles in Uranus’s
orbit. Using information from Leverrier, German astronomer Johann Gottfried Galle first
observed the planet in 1846.
</Paragraph>
</Section>
</FlowDocument>
</FlowDocumentReader>
下图显示了此示例的呈现效果。
注解
Figure 或 Floater 元素常用于突出显示或强调内容的某些部分,托管主内容流中的支持图像或其他内容,或用于注入松散相关的内容,例如广告。 浮点器可以包含继承自 Block 类的对象。 有关详细信息,请参阅 TextElement 内容模型概述
Figure 和 Floater 在多个方面存在差异,并用于不同的方案。
Figure:
可定位:可设置其水平和垂直定位点,以便相对于页面、内容、栏或段落进行停靠。 还可使用其 HorizontalOffset 和 VerticalOffset 属性指定任意偏移量。
可将其大小调整为列大小的几倍:可将 Figure 的高度和宽度设置为页面、内容或列的高度或宽度的倍数。 请注意,对于页面和内容,倍数不能大于 1。 例如,可将 Figure 的宽度设置为“页面的 0.5 倍”、“内容的 0.25 倍”或“列的 2 倍”。 还可将高度和宽度设置为绝对像素值。
Floater:
无法定位,可在能够为其提供空间的任何位置呈现。 不能设置偏移量或锚定 Floater。
不能将其大小调整为列大小的几倍:默认情况下,Floater 的大小为 1 个列大小。 它有一个可设置为绝对像素值的 Width 属性,但是如果此值大于 1 个列宽,则将其忽略并将浮动对象的大小调整为 1 个列大小。 可通过设置正确的像素宽度将其大小调整为小于 1 个列宽,但调整大小与列无关,因此“0.5 倍列宽”并不是 Floater 宽度的有效表达。 Floater 没有 height 属性,并且无法设置高度,高度取决于内容
Floater 分页:如果指定宽度的内容超出了 1 个列高,则浮动对象会断开并显示到下一列、下一页等。
Figure 适合放置希望控制其大小和位置的独立内容,并且可以确信内容适合指定的大小。 Floater 适合放置流动更加自由的内容,其流动方式与主页内容类似,但与主页内容相分离。
构造函数
Floater() |
初始化 Floater 类的新实例。 |
Floater(Block) | |
Floater(Block, TextPointer) |
初始化 Floater 类的一个新实例,其中使用指定 Block 对象作为其初始内容,并由一个 TextPointer 指定新 Floater 的插入位置。 |
字段
HorizontalAlignmentProperty |
标识 HorizontalAlignment 依赖项属性。 |
WidthProperty |
标识 Width 依赖项属性。 |
属性
AllowDrop |
获取或设置一个值,该值指示此元素能否用作拖放操作的目标。 (继承自 ContentElement) |
AreAnyTouchesCaptured |
获取一个值,该值指示在此元素上是否至少捕获了一次触摸。 (继承自 ContentElement) |
AreAnyTouchesCapturedWithin |
获取一个值,该值指示在此元素或其可视化树中的任何子元素上是否至少捕获了一次触摸。 (继承自 ContentElement) |
AreAnyTouchesDirectlyOver |
获取一个值,该值指示在此元素上是否至少按下了一次触摸设备。 (继承自 ContentElement) |
AreAnyTouchesOver |
获取一个值,该值指示在此元素或其可视化树中的任何子元素上是否至少按下了一次触摸设备。 (继承自 ContentElement) |
Background |
获取或设置用于填充内容区域背景的画笔。 (继承自 TextElement) |
BaselineAlignment |
获取或设置 Inline 元素的基线对齐方式。 (继承自 Inline) |
BindingGroup |
获取或设置用于该元素的 BindingGroup。 (继承自 FrameworkContentElement) |
Blocks |
获取一个 BlockCollection,其中包含组成元素内容的顶级 Block 元素。 (继承自 AnchoredBlock) |
BorderBrush |
获取或设置绘制元素边框时使用的 Brush。 (继承自 AnchoredBlock) |
BorderThickness |
获取或设置元素的边框粗细。 (继承自 AnchoredBlock) |
CommandBindings |
获取与此元素关联的 CommandBinding 对象的集合。 (继承自 ContentElement) |
ContentEnd |
获取表示元素中内容末尾的文本指针。 (继承自 TextElement) |
ContentStart |
获取表示元素中内容开头的文本指针。 (继承自 TextElement) |
ContextMenu |
获取或设置上下文菜单元素,每当通过用户界面 (UI 从此元素内) 请求上下文菜单时,应显示该元素。 (继承自 FrameworkContentElement) |
Cursor |
获取或设置在鼠标指针位于此元素上时显示的光标。 (继承自 FrameworkContentElement) |
DataContext |
获取或设置元素参与数据绑定时的数据上下文。 (继承自 FrameworkContentElement) |
DefaultStyleKey |
获取或设置用于在主题中查找此控件的样式模板的键。 (继承自 FrameworkContentElement) |
DependencyObjectType |
获取 DependencyObjectType 包装此实例的 CLR 类型的 。 (继承自 DependencyObject) |
Dispatcher |
获取与此 Dispatcher 关联的 DispatcherObject。 (继承自 DispatcherObject) |
ElementEnd |
获取表示紧接元素末尾之后位置的文本指针。 (继承自 TextElement) |
ElementStart |
获取表示紧邻元素开头之前位置的文本指针。 (继承自 TextElement) |
FlowDirection |
获取或设置一个值,该值指定 Inline 元素中内容流的相对方向。 (继承自 Inline) |
Focusable |
获取或设置一个值,该值指示元素能否得到焦点。 (继承自 ContentElement) |
FocusVisualStyle |
获取或设置一个对象,该对象允许自定义此元素在捕获到键盘焦点时要应用于此元素的外观、效果或其他样式特征。 (继承自 FrameworkContentElement) |
FontFamily |
获取或设置元素内容的首选顶级字体系列。 (继承自 TextElement) |
FontSize |
获取或设置元素内容的字体大小。 (继承自 TextElement) |
FontStretch |
获取或设置元素内容的字体拉伸特征。 (继承自 TextElement) |
FontStyle |
获取或设置元素内容的字体样式。 (继承自 TextElement) |
FontWeight |
获取或设置元素内容的顶级字体粗细。 (继承自 TextElement) |
ForceCursor |
获取或设置一个值,该值指示是否 FrameworkContentElement 应强制用户界面 (UI) 呈现此实例的 属性声明的 Cursor 游标。 (继承自 FrameworkContentElement) |
Foreground |
获取或设置要应用于元素内容的画笔。 (继承自 TextElement) |
HasAnimatedProperties |
获取一个值,该值指示此元素是否具有任何进行动画处理的属性。 (继承自 ContentElement) |
HorizontalAlignment |
获取或设置一个值,该值指示 Floater 对象的水平对齐方式。 |
InputBindings |
获取与此元素关联的输入绑定的集合。 (继承自 ContentElement) |
InputScope |
获取或设置此 FrameworkContentElement 使用的输入的上下文。 (继承自 FrameworkContentElement) |
IsEnabled |
获取或设置一个值,该值指示是否在用户界面 (UI) 中启用此元素。 (继承自 ContentElement) |
IsEnabledCore |
获取一个值,该值成为派生类中 IsEnabled 的返回值。 (继承自 ContentElement) |
IsFocused |
获取一个值,该值确定此元素是否具有逻辑焦点。 (继承自 ContentElement) |
IsInitialized |
获取一个值,该值指示此元素是否已初始化,方法是作为可扩展应用程序标记语言 (XAML) 加载,或者显式调用其 EndInit() 方法。 (继承自 FrameworkContentElement) |
IsInputMethodEnabled |
获取一个值,该值指示是否启用输入法系统(例如输入法编辑器 (IME) )来处理此元素的输入。 (继承自 ContentElement) |
IsKeyboardFocused |
获取一个值,该值表示此元素是否具有键盘焦点。 (继承自 ContentElement) |
IsKeyboardFocusWithin |
获取一个值,该值指示键盘焦点是否位于元素或子元素内的任意位置。 (继承自 ContentElement) |
IsLoaded |
获取一个值,该值指示是否已加载此元素以供显示。 (继承自 FrameworkContentElement) |
IsMouseCaptured |
获取一个值,该值指示此元素是否捕获了鼠标。 (继承自 ContentElement) |
IsMouseCaptureWithin |
获取一个值,该值确定此元素或其元素树中的子元素是否有鼠标捕获。 (继承自 ContentElement) |
IsMouseDirectlyOver |
获取一个值,该值指示在考虑元素组合的情况下,鼠标指针的位置是否与命中测试结果相对应。 (继承自 ContentElement) |
IsMouseOver |
获取一个值,该值指示鼠标指针是否位于此元素(包括可视子元素或其控件组合)上。 (继承自 ContentElement) |
IsSealed |
获取一个值,该值指示此实例当前是否为密封的(只读)。 (继承自 DependencyObject) |
IsStylusCaptured |
获取一个值,该值指示是否将触笔捕获到此元素。 (继承自 ContentElement) |
IsStylusCaptureWithin |
获取一个值,该值确定此元素(包括子元素和控件组合)是否具有触笔捕获。 (继承自 ContentElement) |
IsStylusDirectlyOver |
获取一个值,该值指示在考虑元素组合的情况下,触笔的位置是否与命中测试结果相对应。 (继承自 ContentElement) |
IsStylusOver |
获取一个值,该值指示触笔是否位于此元素(包括可视子元素)上。 (继承自 ContentElement) |
Language |
获取或设置应用于单个元素的本地化/全球化语言信息。 (继承自 FrameworkContentElement) |
LineHeight |
获取或设置各行内容的高度。 (继承自 AnchoredBlock) |
LineStackingStrategy |
获取或设置一种机制,根据该机制来为文本元素内的每一行文字确定一个行框。 (继承自 AnchoredBlock) |
LogicalChildren |
获取一个可用于迭代该元素的逻辑子元素的枚举数。 (继承自 TextElement) |
Margin |
获取或设置元素的边距粗细。 (继承自 AnchoredBlock) |
Name |
获取或设置元素的标识名称。 该名称提供实例引用,以便在分析 XAML 期间构造元素后,编程代码隐藏(如事件处理程序代码)可以引用该元素。 (继承自 FrameworkContentElement) |
NextInline |
获取与此元素对等的下一个 Inline 元素。 (继承自 Inline) |
OverridesDefaultStyle |
获取或设置一个值,该值指示此元素是否合并了主题样式的样式属性。 (继承自 FrameworkContentElement) |
Padding |
获取或设置元素的填充厚度。 (继承自 AnchoredBlock) |
Parent |
获取此元素的逻辑树中的父级。 (继承自 FrameworkContentElement) |
PreviousInline |
获取与此元素对等的上一个 Inline 元素。 (继承自 Inline) |
Resources |
获取或设置当前本地定义的资源字典。 (继承自 FrameworkContentElement) |
SiblingInlines |
获取一个 InlineCollection,它包含与此元素同级(对等)的 Inline 元素。 (继承自 Inline) |
Style |
获取或设置此元素要使用的样式。 (继承自 FrameworkContentElement) |
Tag |
获取或设置任意对象值,该值可用于存储关于此元素的自定义信息。 (继承自 FrameworkContentElement) |
TemplatedParent |
获取对此元素的模板父级的引用。 如果该元素不是通过模板创建的,则此属性无关。 (继承自 FrameworkContentElement) |
TextAlignment |
获取或设置一个值,该值指示文本内容的水平对齐方式。 (继承自 AnchoredBlock) |
TextDecorations |
获取一个 TextDecorationCollection,它包含要应用于此元素的文本修饰。 (继承自 Inline) |
TextEffects |
获取或设置应用于元素内容的文本效果集合。 (继承自 TextElement) |
ToolTip |
获取或设置用户界面 (UI) 中为此元素显示的工具提示对象。 (继承自 FrameworkContentElement) |
TouchesCaptured |
获取在此元素上捕获的所有触摸设备。 (继承自 ContentElement) |
TouchesCapturedWithin |
获取在此元素或其可视化树中的任何子元素上捕获的所有触摸设备。 (继承自 ContentElement) |
TouchesDirectlyOver |
获取此元素上的所有触摸设备。 (继承自 ContentElement) |
TouchesOver |
获取在此元素或其可视化树中的任何子元素上的所有触摸设备。 (继承自 ContentElement) |
Typography |
获取该元素内容的当前有效的版式变体。 (继承自 TextElement) |
Width |
获取或设置一个值,该值指示 Floater 对象的宽度。 |
方法
事件
显式接口实现
IAddChild.AddChild(Object) |
添加子对象。 (继承自 TextElement) |
IAddChild.AddText(String) |
将节点的文本内容添加到对象。 (继承自 TextElement) |
IQueryAmbient.IsAmbientPropertyAvailable(String) |
有关此成员的说明,请参见 IsAmbientPropertyAvailable(String) 方法。 (继承自 FrameworkContentElement) |