首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在单个UserControl中使用两次相同的MahApps按钮样式不起作用

的原因可能是由于样式的冲突或者重复定义导致的。为了解决这个问题,可以尝试以下几种方法:

  1. 确保引用了正确的MahApps.Metro库:首先要确保项目中引用了正确版本的MahApps.Metro库,并且在XAML文件中正确地声明了MahApps.Metro的命名空间。
  2. 使用不同的样式名称:如果在同一个UserControl中使用了两次相同的按钮样式,可以尝试给其中一个按钮指定一个不同的样式名称,以避免样式冲突。
  3. 使用DynamicResource而不是StaticResource:在XAML中,可以尝试使用DynamicResource而不是StaticResource来引用按钮样式。DynamicResource会在运行时动态地解析样式,而StaticResource会在编译时就确定样式,可能会导致样式冲突。
  4. 检查样式定义的位置:确保按钮样式的定义在UserControl的资源部分,并且没有被其他样式或者控件的样式所覆盖。
  5. 检查样式的作用范围:确保按钮样式的作用范围适用于需要应用样式的按钮。可以在样式的TargetType属性中指定按钮的类型,或者使用BasedOn属性继承其他样式。

总结起来,解决在单个UserControl中使用两次相同的MahApps按钮样式不起作用的问题,可以通过确保引用了正确的MahApps.Metro库、使用不同的样式名称、使用DynamicResource、检查样式定义的位置和样式的作用范围等方法来解决。具体的解决方法可以根据实际情况进行调整和尝试。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

.NET Core.NET5.NET6 开源项目汇总11:WPF组件库1

通过XAML工具箱中的设计,可以使用现代流行的设计语言轻松地将漂亮的桌面应用程序带到生活中。...组件特征 支持大多数标准WPF控件的样式和变体 更多的附加控件,以支持材质设计的美观性和流动性 在设计和运行时轻松配置材质设计调色板 用于轻松构建GUI动画的转换API 独立工作,也与其他流行的WPF框架...3、按钮 多种形状的交互按钮,如圆形按钮、图标按钮、按钮进度、按钮文字提示等等,Web中常见的效果WPF中也可以简单地使用。 ?...4、输入验证框 表单验证,常规做法是在ViewModel中写业务逻辑验证代码,或者在XAML中写验证表达式。...开源     MahApps.Metro的源代码托管在GitHub上,包含了自己构建它所需的一切,所以请访问并帮助我们改进它。 功能展示 ? ?

2.9K30

为Form和自定义Window添加FunctionBar

前言 我常常看到同一个应用程序中的表单的按钮————也就是“确定”、“取消”那两个按钮————实现得千奇百怪,其实只要使用统一的Style起码就可以统一按钮的大小,而我喜欢更进一步将”确定“、”取消“或其它按钮封装进一个自定义控件里...这篇文章介绍了另一种ItemsControl的实现方式,并使用它为表单及自定义Window添加常用的按钮及其它功能。 2....这样做可以统一所有Form的按钮。由于做得很简单,后期可以再按需要添加其他控件的样式。...在FormFunctionBar我通过Trigger设置了IsDefault=True的按钮比其它按钮更长。 3....为自定义Window添加按钮 为自定义Window在标题栏添加一些按钮也是个常见的需求,原理和FormFunctionBar一样,只需要在自定义的Window的适当位置放置一个PlaceHolder,然后把

77630
  • Scrivener for Mac如何自定义快捷键

    并且支持用户使用关键词跟踪主题,动态联合多种场景到单个文本,从而辅助作者完成从作品构思、搜集资料、组织结构、增删修改到排版输出的整个写作流程,能够适用于博主、作家、专栏作者使用。...在Scrivener for Mac中分配或更改键盘快捷键 可能存在某些菜单项,您发现自己使用了很多没有键盘快捷键的菜单项,或者您发现键盘快捷键过于复杂。...2、如有必要,请单击顶部的“全部显示”。 3、在“硬件”部分下,单击“键盘”(或Leopard及以下的“键盘和鼠标”)。 4、在“键盘(和鼠标)”窗格中,选择“键盘快捷键”选项卡。...5、在左侧列表中选择“应用程序快捷方式”(请注意,Leopard及以下不需要此步骤)。 6、单击“+”按钮。将出现一张纸。 7、从“应用程序”弹出按钮,选择Scrivener。...例如,Edit > Add Link…菜单项有时可以更改其标题, Edit > Edit Link…因此,要为该项目添加一致的键盘快捷方式,您需要两次添加相同的快捷方式,一次为“添加链接…”,再次为“编辑链接

    1.8K20

    如何让 WPF 程序更好地适配 UI 自动化

    容器与布局类的控件并没有暴露给 UI 自动化(例如 Grid、StackPanel、Border 等,并没有出现在自动化测试中)。 用户控件(UserControl)暴露给了 UI 自动化。...下面,我列举几个例子: 本来给按钮(Button)设置文本属性用的是 Content 属性,但某天想做很特别的样式,单独在模板(Template)里面写死了文本,而没有直接设置按钮的 Content 属性...尽量使用通用控件来做控件对应的交互(例如像一个按钮那就用按钮,像一个组合框那就用组合框),而不是使用 Grid、Border 等用来布局或装饰的控件来随意处理。...本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。

    50320

    14.7K Star一套遵循谷歌设计规范的C#控件库

    微信公众号:[开源日记],分享10k+Star的优质开源项目 MaterialDesignInXamlToolkit 是一个开源的、专为 WPF 应用程序设计的 UI 控件库,它允许开发者在 C# 或...这个工具包不仅提供了丰富的控件和样式,还包含了多种转换效果,使得开发者能够创建出既现代化又具有吸引力的桌面应用程序。...功能特点 1.控件和样式:为 WPF 框架中的大多数主要控件提供 Material Design 风格的样式和变体。...2.额外控件:包含额外的控件,如多动作按钮、卡片、对话框和时钟,以支持 Material Design 的美学和流程。...5.兼容性:与流行的 WPF 框架 MahApps 和 Dragablz 兼容,可以独立使用或与其他框架结合使用。 6.MVVM 框架中立:不依赖于特定的 MVVM 框架,提供了更大的灵活性。

    11510

    使用通用附加属性来减少 WPF 元素自定义样式的多余代码

    一、自定义元素样式的方法 在开发 WPF 应用的过程中,我们常常需要给元素设置样式,其中一种方法是创建自定义样式,套路如下: 在设计器的元素上右键 --> 编辑模板 --> 编辑副本: 选择名称和位置后点击确定即可创建...这里有一个设置圆角的例子: 这里样式中绑定了 WpfXamlPropProxy.CornerRadius,默认值为 5,在元素或者子样式中就可以对其更换为其它的值: 四、使用附加属性让控件模板可共用...4.1、问题:给触发器中要设定的值绑定附加属性没效果 现象:在元素样式的控件模板的Triggers 中,在某个 Trigger 的某个 Setter 的 Value 中想绑定样式中设置的某个附加属性,结果提示找不到该属性...(codenong.com) 附加属性上的 WPF 触发器不起作用 - IT 工具网 (coder.work) 4.2、方法:使用代理元素在触发器中绑定附加属性 解决方法:在控件模板中添加一个隐藏的...Template 部分和主样式也就相同了,也就可以删除了。

    2K20

    WPF 从 用户控件 到 自定义控件

    WPF 从 用户控件 到 自定义控件 独立观察员 2024 年 4 月 29 日 一、用户控件示例:能够朝向上下左右四种方向 在 WPF 中,如果想要复用 Xaml 代码,最先想到的肯定是用户控件(UserControl...但是,由于这些属性一般具有重复性,所以和其它控件元素使用时一样,也就是如果在某个容器内有一系列相同元素,而且它们的很多属性也是会被设置为相同的,那么这时一般会在该容器的资源中添加一个针对该元素的样式,而且一般不设置...UserControl 的 Style 里,会导致外面使用时,给 UserControl 设置全局样式时不生效(尤其是对于依赖属性),可按照如下结构改造: 不过这又导致在 UserControl 上设置了默认值的属性...【尝试】在用户控件资源中添加目标类型为自己的样式,在其中设置需要设置的默认值: 在使用时会提示未找到相关资源: 这个想想也正常,相关样式资源是定义在用户控件内部的,在外面自然是访问不到的。...,自带属性改为使用 TemplateBinding 进行绑定,依赖属性使用 Binding 进行绑定,可以使用 Setter 设置默认值: (有个缺点:绑定的依赖属性在 Xaml 中无法定位过去,这可能是

    17810

    C# WPF MVVM项目实战(进阶①)

    这篇文章还是在之前用Caliburn.Micro搭建好的框架上继续做的开发,今天主要是增加了一个用户窗体TestFormView,然后通过TabControl,将新增的窗体加载到主界面上进行分页显示,新增的页面引用了...01 — 重要的知识点 本篇内容基于CM框架编写,涉及以下知识点: ① 将UserControl添加到主窗体: 首先在主窗体viewmodel中定义UserControl public TestFormViewModel...TestFormView { get; set; } 然后在构造函数中实例化: TestFormView = new TestFormViewModel(); 最后在主窗体XMAL中附加引用:... ③表头合并:代码较长,此处省略 ④使用样式...Property="Background" Value="LightGray"/> 引用: 在需要引用的视图中把编写好的样式合并进来

    2K20

    WPF 做一个超级简单的 1024 数字接龙游戏

    此时点击列表下方的 “点击” 按钮,即表示将最右边的数字放在这一列表中 如下图,就是点击了首个列表的“点击”按钮,将上图的 1024 数字放在首个列表里 如下图,首个列表里面的最后一个是 2 的数字,最右边的数字也是...忽略其他代码 UserControl> 如上图界面,可以看到每个列表下方都有一个点击按钮。...,配置下面一行给按钮使用,按钮需要多少空间再给多少空间 修改之后的 CecaqemdarYefarqukeafai.xaml 的全部代码如下 UserControl x:Class="BawjadurbaWurahuwa.CecaqemdarYefarqukeafai...> 可以看到实现非常简单,即使不使用用户控件也是可以的 这里的点击按钮需要将事件给到外面订阅,编辑后台 CecaqemdarYefarqukeafai.xaml.cs 代码,实现按钮点击逻辑,代码如下...collection.RemoveAt(collection.Count - 1); 代码移除,为什么两次移除都是相同的代码?

    9810

    “XXX”在元素“ZZZ”的范围内,在另一范围内定义它时,已注册了名称。

    -- 省略 --> UserControl.Style> UserControl> 别问我为什么会有以上这样诡异的代码。我也不知道,这只是偶然发现的代码,我简化后拿到博客中。...CustomControl 然后在 /Themes/Generic.xaml 里写样式。...至于以上 XAML 代码中我看到用的是 UserControl.Style> 来写样式,是因为踩到了当控件用的另一个坑: 所有在控件的 XAML 中设置的 Content 属性都将被使用时覆盖。...将 UserControl.Style> 里定义的所有样式全部改到 /Themes/Generic.xaml 文件中。...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布

    3.1K20

    C#实现多个子窗体切换效果

    今天来和大家分享一下在C#的winform开发中如何实现借助一个主窗体来实现内部多个子窗体的切换效果。 首先来看一下主窗体中多个小窗体切换的效果: ?...多窗体切换的原理:多窗体切换的原理其实是借助一个panel容器,在该容器中显示相同大小的窗口, 接下来大灰狼和大家分享一下建立多窗口切换的步骤: 1、新建一个主窗体并在其中放置适当的控件,包括进行切换的按钮和显示窗体的...2、新建用于在主窗体中显示的子窗体,子窗体的新建其实是一个用户控件(Windows窗体),在这里我们可以在状态栏中右击选择—>添加—>用户控件(Windows窗体) ?...5、在主窗体的代码中定义相应的三个窗口变量, public UserControl1 f1; //创建用户控件一变量 public UserControl2 f2; //...双击主窗体中的按钮进入相应的触发函数,在这里我们要使用如下的代码对相应的子窗体进行显示: //显示窗体一 private void button1_Click(object

    4.8K30

    成为一名高级 React 需要具备哪些习惯,他们都习以为常

    完成的待办事项被存储在状态中两次,所以如果用户编辑待办事项的文本内容,你只调用setTodos, completedTodos现在包含旧的文本,这是不正确的! 有一些方法可以去复制你的状态。...在对抗糟糕的渲染性能时,你最强大的武器是React.memo,它只在组件的道具更改时才重新呈现组件。这里的挑战是确保道具不会在每次渲染中改变,在这种情况下React。备忘录不起作用。...在显示表单时,使用粗体颜色来吸引用户注意提交按钮!如果有一个永久删除某些内容的按钮,它最好是红色的!查看Bootstrap的按钮和提醒来了解这一点。...Sass和其他CSS预处理器添加了一些非常棒的功能,但在很大程度上仍然存在与普通CSS相同的问题。 我认为样式应该被定义为单独的React组件,CSS应该和React代码放在一起。...将CSS的范围限定在单个组件上,可以将组件重用为共享样式的主要方法,并防止样式意外应用到错误元素上的问题。

    4.7K40

    Qt贴图与Qss快速入门(一)

    前两次和大家分享了Qml绘制仪表盘、Qt自定义控件绘制仪表盘,我是更倾向使用Qml这种方式的。自定义控件使用到了定时器,如果有多个控件的话,那岂不是要使用很多定时器?...对应我的界面就是“立即体检”的绿色部分、下面三个按钮的灰色部分以及点击第一个按钮跳转到的部分。 下载的程序是用纯代码写的,但我的都是使用Qt Designer来做的。...这是直接在Widget中设置的样式,要注意的是QWidget直接派生类的样式表是不起作用的,原因是QWidget的paintEvent()是空的,而样式表要通过paint被绘制到窗口中。...(:/resource/safe_check)0 285 0 0"); 这里要提一下的是safe_check.png图片是4张连在一起的,所以在设置样式表时需要将图片分割,取出需要使用的图片,这里面取出来的是第一张图片...这几个窗体中,当点击按钮时,会将发出信号,在Dialog窗体中将信号与槽连接起来。 ? 4. Dialog窗体 该窗体中主要实现了动画的效果,还有就是将需要的信号和槽进行连接。

    1.5K30

    WPF 用户控件翻转与内部的内容控件反翻转

    在用户控件内部就是分别给面板以及内容控件设置对应的样式: 以及,前面提到的 RenderTransform 不被占用仍可使用的情况如下: 在外部使用用户控件时,只需在需要水平翻转的那个控件上设置 Orientation...=”Right” 即可: 既然本次演示的都是 Sty.JudgeFlip.H.ContentControl.BindUc ,那么在 VM 中自然是需要也有一个 Orientation 属性的: 然后在用户控件后台代码中...此时有人可能就要说了,为什么不直接全部使用 ViewModel 中的相关属性呢?...这是因为如果不使用控件后台代码的方向属性,那么在设计视图则不会有翻转的效果,换句话说,如果你有左右两个对称的控件,那么在设计视图中,它们可能都是 “左脚” 的形式,这样就不利于控件的排布设计等。...当然,你可以使用设计时 DataContext 等技术,但是那样好像更麻烦了。 最后说一句,本文介绍的是水平翻转的情况,而对于垂直翻转的情况,其道理是相同的。

    8310
    领券