- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人可以向我解释为什么 VerticalContentAlignment
似乎无法在 Dockpanel
内的 3 个文本框上工作吗?
文本与顶部对齐,VerticalContentAlignment
的值均无效。我试过删除所有边距和填充以及弄乱文本框以及所有父控件的 VerticalAlignment
和 VerticalContentAlignment
属性。
在线搜索返回的结果很少,而且似乎没有一个与我的场景相关。
这是我的 XAML:
<UserControl>
<Grid Background="{StaticResource Primary}">
<Grid.RowDefinitions>
<RowDefinition Height="45" />
<RowDefinition MinHeight="100"/>
<RowDefinition Height="55" />
</Grid.RowDefinitions>
<DockPanel Grid.Row="0">
<Label Content="Opacity Width:" Foreground="#FFF" VerticalContentAlignment="Center" FontSize="16"></Label>
<TextBox Background="{StaticResource PrimaryDark}" BorderBrush="#DFE3E9" BorderThickness="0" Foreground="#67737C" Margin="5" VerticalContentAlignment="Center"
Text="{Binding OpacitiesWidth}" Padding="0" HorizontalContentAlignment="Center" Width="50" />
<Label Content="Opacity Height:" Foreground="#FFF" VerticalContentAlignment="Center" FontSize="16" />
<TextBox Background="{StaticResource PrimaryDark}" BorderBrush="#DFE3E9" BorderThickness="0" Foreground="#67737C" Margin="5" VerticalContentAlignment="Center"
Text="{Binding OpacitiesHeight}" Padding="0" HorizontalContentAlignment="Center" Width="50" />
<Label Content="Brightness Factor:" Foreground="#FFF" VerticalContentAlignment="Center" FontSize="16"></Label>
<TextBox Background="{StaticResource PrimaryDark}" BorderBrush="#DFE3E9" BorderThickness="0" Foreground="#67737C" Margin="5" VerticalContentAlignment="Center"
Text="{Binding OpacitiesBrightnessFactor}" Padding="0" HorizontalContentAlignment="Center" Width="50" />
<controls:FlatButton DockPanel.Dock="Right" Background="{x:Null}" ColorHover="{x:Null}" ColorPressed="{x:Null}" FontFamily="/Resources/#fontello"
Foreground="#8F96A1" ForegroundHover="#8F96A1" FontSize="20" Content="" Width="50" BorderThickness="0"
Command="{Binding CommandRandomize}" />
</DockPanel>
<Border Grid.Row="1" Margin="10,0">
<ListView Background="{x:Null}" BorderBrush="{x:Null}" BorderThickness="0" ItemsSource="{Binding Opacities}" ScrollViewer.VerticalScrollBarVisibility="Disabled">
<ListView.ItemContainerStyle>
<Style TargetType="{x:Type ListViewItem}">
<Setter Property="Background" Value="Transparent" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ListViewItem}">
<ContentPresenter />
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</ListView.ItemContainerStyle>
<ListView.ItemsPanel>
<ItemsPanelTemplate>
<StackPanel Orientation="Horizontal" ScrollViewer.HorizontalScrollBarVisibility="Visible"
ScrollViewer.VerticalScrollBarVisibility="Disabled" />
</ItemsPanelTemplate>
</ListView.ItemsPanel>
<ListView.ItemTemplate>
<DataTemplate>
<Border Margin="5">
<Rectangle Fill="{Binding Fill}" Width="64" Height="64">
</Rectangle>
</Border>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
</Border>
<controls:FlatButton Grid.Row="3" DockPanel.Dock="Right" Background="{StaticResource Secondary}" ColorHover="{StaticResource SecondaryLight}" ColorPressed="{StaticResource Secondary}"
Foreground="#FFF" ForegroundHover="#8F96A1" FontSize="20" Content="Debug" BorderThickness="0" Command="{Binding CommandDebug}" Margin="0" VerticalContentAlignment="Center" />
</Grid>
</UserControl>
编辑
如果我将我的代码移动到一个新的 WPF 解决方案中,VerticalContentAlignment
工作得很好。我的解决方案有问题,但我不确定是什么。
EDIT2
问题是我的自定义滚动条样式。谁能帮我弄清楚如何编辑它,以免它干扰我的文本框?
<Style TargetType="{x:Type ScrollViewer}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ScrollViewer}">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition Height="Auto"/>
</Grid.RowDefinitions>
<ScrollContentPresenter Grid.Column="0" />
<ScrollBar x:Name="PART_VerticalScrollBar" Grid.Row="0" Grid.Column="1" Value="{TemplateBinding VerticalOffset}" Maximum="{TemplateBinding ScrollableHeight}" ViewportSize="{TemplateBinding ViewportHeight}" Visibility="{TemplateBinding ComputedVerticalScrollBarVisibility}"/>
<ScrollBar x:Name="PART_HorizontalScrollBar" Orientation="Horizontal" Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="1" Value="{TemplateBinding HorizontalOffset}" Maximum="{TemplateBinding ScrollableWidth}" ViewportSize="{TemplateBinding ViewportWidth}" Visibility="{TemplateBinding ComputedHorizontalScrollBarVisibility}"/>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style x:Key="ScrollThumbs" TargetType="{x:Type Thumb}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate>
<Grid>
<Border x:Name="Rectangle1" Background="{StaticResource PrimaryLight}" CornerRadius="5" HorizontalAlignment="Stretch" VerticalAlignment="Stretch">
<Rectangle HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Fill="Transparent" />
</Border>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="Tag" Value="Horizontal">
<Setter TargetName="Rectangle1" Property="Width" Value="Auto" />
<Setter TargetName="Rectangle1" Property="Height" Value="Auto" />
</Trigger>
<Trigger Property="Tag" Value="Vertical">
<Setter TargetName="Rectangle1" Property="Background" Value="Red" />
<Setter TargetName="Rectangle1" Property="Width" Value="Auto" />
<Setter TargetName="Rectangle1" Property="MinHeight" Value="450" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style x:Key="{x:Type ScrollBar}" TargetType="{x:Type ScrollBar}">
<Setter Property="SnapsToDevicePixels" Value="True" />
<Setter Property="OverridesDefaultStyle" Value="true" />
<Setter Property="Template" Value="{DynamicResource ScrollbarTrack}" />
<Style.Triggers>
<Trigger Property="Orientation" Value="Horizontal">
<Setter Property="Width" Value="Auto" />
<Setter Property="Height" Value="10" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ScrollBar}">
<Grid>
<Border CornerRadius="5" Background="{StaticResource PrimaryDark}" VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
<Track x:Name="PART_Track" Grid.Row="0" IsDirectionReversed="False">
<Track.IncreaseRepeatButton>
<RepeatButton x:Name="PageUp" Command="ScrollBar.PageDownCommand" Opacity="0" Focusable="false" />
</Track.IncreaseRepeatButton>
<Track.Thumb>
<Thumb x:Name="Thumb" Background="{TemplateBinding Foreground}" Style="{DynamicResource ScrollThumbs}" />
</Track.Thumb>
<Track.DecreaseRepeatButton>
<RepeatButton x:Name="PageDown" Command="ScrollBar.PageUpCommand" Opacity="0" Focusable="false" />
</Track.DecreaseRepeatButton>
</Track>
</Border>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Trigger>
<Trigger Property="Orientation" Value="Vertical">
<Setter Property="Width" Value="10" />
<Setter Property="Height" Value="Auto" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ScrollBar}">
<Grid>
<Border CornerRadius="5" Background="{StaticResource PrimaryDark}" VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
<Track x:Name="PART_Track" Grid.Row="0" IsDirectionReversed="True">
<Track.IncreaseRepeatButton>
<RepeatButton x:Name="PageUp" Command="ScrollBar.PageDownCommand" Opacity="0" Focusable="false" />
</Track.IncreaseRepeatButton>
<Track.Thumb>
<Thumb x:Name="Thumb" Background="{TemplateBinding Foreground}" Style="{DynamicResource ScrollThumbs}" />
</Track.Thumb>
<Track.DecreaseRepeatButton>
<RepeatButton x:Name="PageDown" Command="ScrollBar.PageUpCommand" Opacity="0" Focusable="false" />
</Track.DecreaseRepeatButton>
</Track>
</Border>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Trigger>
</Style.Triggers>
</Style>
最佳答案
很抱歉延迟回复,这几周很有趣。无论如何,让我们继续发布一些内容,以帮助 future 的读者避免一些评论困惑,这可能会在未来帮助某人(我是传播学习和帮助的忠实粉丝)sooo...
最初您的问题实际上是一个非常普遍的问题,尤其是当有人可能对 DOM 和属性继承等事物不熟悉时。我最常见于那些可能将大部分时间花在代码端而不是表示层上的人。就像在这种情况下,那些精通 C# 的人(它本身在旧的脑盒中占用了大量空间)但通常只是在布局方面破解它。这就是为什么我通常提倡在团队成员之间分离表示层的那些部分以利用彼此的优势,因为任何一个领域都需要大量的知识/经验保留才能真正精通。
无论如何,在使用各种 CLI/SDK 控件时,重要的是要记住这些小家伙所遵循的级联继承模型,以帮助鼓励 D.R.Y.发展。因此,例如,如果您使用的是 RadioButton
,那么它从家谱树中的 ToggleButton
类派生很重要。或者在这种情况下,一个 TextBox
包含一个 ScrollViewer
作为其基本样式模板中的子元素。
这是共享资源的一个例子,当我们可能编辑/自定义一个资源但忘记它仍然必须与另一个很好地发挥作用时,共享资源可以迅速成为彼此之间的罪魁祸首。
所以通过做类似的事情;
<Style TargetType="ScrollViewer">
<!-- Our customizations necessary for our instance scenario here -->
</Style>
....然后取决于这个家伙在继承树中的位置,它可能会对其他控件(例如 TextBox
、ListBox
)产生不良影响、ListView
、TreeView
、Menu
或一些可能依赖于 ScrollViewer
的控件他们运营的一部分。
现在,如果您要创建的这个新模板需要在多个地方应用而不干扰需要原始默认样式模板来控制它的其他元素,那么一个简单的方法就是在我们需要的地方显式定义这个样式覆盖例如;
In a resource dictionary;
<Style TargetType="ScrollViewer" x:Key="OurSuperCoolNewScrollViewerStyleTemplate">
<!-- Our customizations necessary for our instance scenario here -->
</Style>
Then in at the instance declared as a StaticResource or a DynamicResource respectively;
<ScrollViewer Style="{StaticResource OurSuperCoolNewScrollViewerStyleTemplate}"/>
这样就可以控制我们将在何处应用我们的新资源,而不是通过简单地声明 TargetType
来证明它是可继承的覆盖,这将命中相同类型的任何实例。除了当我们有多个需要相同样式的相同元素但我们只希望它们自动继承而无需隐式声明时,这会变得乏味和不必要吗?那么我们通过 BasedOn
来利用继承建模,例如;
<StackPanel>
<StackPanel.Resources>
<Style TargetType="ScrollViewer"
BasedOn="{StaticResource OurSuperCoolNewScrollViewerStyleTemplate}"/>
</StackPanel.Resources>
<ScrollViewer/>
<TextBox/>
<ListBox/>
</StackPanel>
在这种情况下,具有类型为 ScrollViewer
的嵌入式控件的 StackPanel
的所有子项都将继承新的 Style
模板。
但是,对于这种情况有一个警告。有时,将 Style
模板放入 ResourceDictionary
并不是最佳做法,因为 ResourceDictionary
会在运行时加载其中的所有内容。所以假设我们遇到一个实例,我们可能只需要对很少使用的小区域或单个元素应用一些小的更改。因此,在这种情况下,与其无缘无故地进一步膨胀我们的 ResourceDictionary
,不如因为它只是一个很少使用的临时场景,有时最好为单个实例隐式应用整个 Style 模板,例如;
<TextBox>
<TextBox.Resources>
<Style TargetType="ScrollViewer">
<!-- Our customizations necessary for our instance scenario here -->
</Style>
</TextBox.Resources>
</TextBox>
无论如何,希望这对您有所帮助,很高兴您找到了罪魁祸首!干杯!
关于WPF 文本框 VerticalContentAlignment 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50108995/
有没有办法在另一个 WPF 窗口内托管 WPF 窗口。我有几个有点复杂的表格。但现在为了简化事情,我试图将其中一些合并为一个“仪表板”表单中的标签页。 请注意,我不是要托管 Windows 窗体,而是
WPF 特有的哪些方面和实践在非 WPF GUI 编程中最有用(并且并非难以实现)? 最佳答案 通过学习 WPF 命令,我了解了命令模式。它构成了 UI - 代码分离的基础,我认为应该在其他应用程序中
WinRT/Metro 正在获得一个新的 SemanticZoom控制,但我很难为 WPF 找到任何东西。 我不想为我的特定项目切换到 Metro,因为它不允许我制作窗口应用程序或跨多个显示器的多个实
我很难解决我的问题,我快要疯了。 想法是这样的:我有两个 ListView 元素,当一个元素从第一个列表掉落到第二个列表时,我需要打开一个对话,但我需要被掉落的元素的信息以及被添加以填充对话的元素。
如果我遵循TabControl,并且一切正常,当我切换到第二个Tabitem时,它显示就没有问题。 //datagrid //datagrid2 但是如果我有这个xaml,当我
在 Windows 窗体应用程序中,我们的数据 GridView 有很多事件,如行鼠标双击或行单击以及额外的...... 但是在 WPF 中我找不到这些事件。我如何将行鼠标双击添加到其中包含数据网格的
在这个项目中,代码 正确编译和执行 ;但是,我需要帮助解决两个问题: VS2012 WPF 设计器不适用于此 XAML 文件。它显示消息设计 View 对于 x64 和 ARM 目标平台不可用。 我收
目前我正在设计 WPF ScrollViewer,我发现了这个 Content="M 0 0 L 4 4 L 0 8 Z" 阅读 MSDN examples .现在我真的很想知道这意味着什么,但我无法
在 WPF 中,元素的可见性可以为“可见”,但实际上在屏幕上不可见,因为它的父元素(或父元素的父元素)具有折叠的可见性。 我希望能够知道一个元素是否实际呈现在屏幕上,而不必遍历可视化树检查父元素。 有
我应该使用 ApplicationCommands.Close用于关闭模式对话框还是该命令被认为是为关闭应用程序保留的?如果是后者,请大家创建Close每个命令 Dialog盒子或只是一个 Close
WPF 是否有任何可用的 piemenu 控件? 最佳答案 我在我的最爱中找到了这个,你可以看看: This 祝你今天过得愉快。 关于wpf - WPF 的菜单,我们在Stack Overflow上找
我正在尝试使用 WrapPanel 和两个 TextBlock 将星号 (*) 附加到某些文本的左侧,允许文本换行,并强制文本右对齐。通过创建一个 FlowDirection 设置为 RightToL
这里是场景(简化):我在Window上有一个控件(比如说一个Rectangle)。我迷上了MouseMove事件,以使其启动拖放操作。然后在MouseDown事件中进行动画处理,向右移动50个像素。但
我有一个 ListView ,它的项目来源是一个列表。我希望用户只选择一项。当我将 listview 的 SelectionMode 设置为 single 时,用户仍然可以选择多个项目,并且似乎 li
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
INotifyPropertyChanged 的目的是什么。我知道每当更改属性时都会触发此事件,但是 View /用户界面如何知道触发了此事件: 这是实现 INotifyPropertyChang
我正在查看工具箱中的 WPF 组件,但找不到 2005/2008 中存在的错误提供程序。 被移除了吗? 最佳答案 ErrorProvider是一个 Winforms 控件。 WPF 中没有等效项。但是
我试图在单击和双击 wpf Image 控件时有不同的行为。不幸的是,单击首先被触发,因此双击被忽略。 最佳答案 如果您改用 MouseDown 事件,则它在 EventArgs 中为 ClickCo
这可能吗? 我使用了一个框架控件并且:显示(例如:showwindow.xaml) 但是我得到这个错误: root element is not valid for navigation 最佳答案 确
我在蓝色背景的窗口上放置了一个扩展器,我想让扩展器的按钮与默认颜色不同(蓝色,它是从窗口接收的)。当我修改扩展器的背景属性时,它会将整个扩展器、标题和全部更改为新颜色。但是,我只想更改按钮本身。谁能指
我是一名优秀的程序员,十分优秀!