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

根据ListBox.SelectedIndex在WPF中启用按钮

根据ListBox.SelectedIndex在WPF中启用按钮,可以使用以下代码实现:

代码语言:csharp<Window x:Class="WpfApp1.MainWindow"
复制
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfApp1"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <Grid.ColumnDefinitions>
           <ColumnDefinition/>
           <ColumnDefinition/>
        </Grid.ColumnDefinitions>
        <ListBox x:Name="listBox" SelectionChanged="listBox_SelectionChanged">
            <ListBoxItem Content="Item 1"/>
            <ListBoxItem Content="Item 2"/>
            <ListBoxItem Content="Item 3"/>
        </ListBox>
       <Button x:Name="button" Content="Click me" IsEnabled="False" Grid.Column="1"/>
    </Grid>
</Window>

在代码隐藏文件中,可以添加以下代码:

代码语言:csharp
复制
using System.Windows;

namespace WpfApp1
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }

        private void listBox_SelectionChanged(object sender, System.Windows.Controls.SelectionChangedEventArgs e)
        {
            if (listBox.SelectedIndex >= 0)
            {
                button.IsEnabled = true;
            }
            else
            {
                button.IsEnabled = false;
            }
        }
    }
}

这样,当ListBox中的选中项发生变化时,如果选中了一个项,则按钮将被启用,否则将被禁用。

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

相关·内容

WPF 实现融合效果

之前的一篇文章,我使用 Win2D 实现了融合效果,效果如下: 不过 Win2D 不适用于 WPF WPF 可以使用 BlurEffect 配合自定义 Effect 实现类似的效果。...自定义 Effect Win2D ,实现融合效果的步骤是先使用 GaussianBlurEffect 两个元素间产生粘连在一起的半透明像素,再用 ColorMatrixEffect 加强对比对,... WPF 我们可以直接使用自带的 BlurEffect 实现高斯模糊,效果如下: 接下来需要加强对比度。...WPF 没有 ColorMatrixEffect 的替代品,不过我们可以使用 HLSL(高级着色器语言)编写 PixelShader 并生成自定义的 WPF Effect。...很明显,问题出在上面的代码 Alpha 通道最终不是 0 就是 1,为了使边缘平滑,应该留下一些“中间派”。

1.2K20

Spring AOP切面启用新事务

在工作中有一个切面需要记录一下操作日志的需求,而且要求这些操作日志要存入数据库,并且无论业务层有什么异常,日志照常记录,那就不能沿用业务层的事务,而是需要新启一个事务了。...sping的声明式事务就是靠AOP来实现的,一般事务都在业务层启用,那如果要在AOP的逻辑启用一个新的事务要怎么做呢?...,需要启用新的事务 ... } 经过我的测试,通过doAfterReturning方法上加上注解@Transactional,并指定传播行为是REQUIRES_NEW依然不行。..."remote()") public void doAfterReturning(JoinPoint joinPoint,Object ret) throws Throwable { //声明式事务切面不起作用...,执行完就会提交,和业务层的原事务无关,即便执行完切面逻辑后继续执行业务代码的过程中出现异常,业务层的数据库操作因为有原事务而回滚,但切面的数据库操作不会回滚,因为这是个新的事务!

62510

FluentValidationC# WPF的应用

其实它也可以用于WPF属性验证,本文主要也是讲解该组件WPF的使用,FluentValidation官网是: https://fluentvalidation.net/ 。...本文需要实现的功能unsetunset 提供WPF界面输入验证,采用MVVM方式,需要以下功能: 能验证ViewModel定义的基本数据类型属性:int\string等; 能验证ViewModel定义的复杂属性...集合类 - Field 此类用作ViewModel的集合项使用,模拟动态表单数据校验,简单包含4个属性:字段名称、字段显示名称、数据类型、数据值,表单主要根据数据类型验证输入的数据值是否合法。...创建验证器 验证属性的写法有两种: 可以实体属性上方添加特性(本文不作特别说明,百度文章介绍很多); 通过代码的形式添加,如下方,创建一个验证器类,继承自AbstractValidator,在此验证器构造函数写规则验证属性...及Field类似,这里我加上了保存(SaveCommand)和取消(CancelCommand)两个命令,其中保存命令需要所有属性验证通过才可用,通过注册属性的变化事件PropertyChanged,变化事件处理程序验证

11810

Excel,如何根据值求出其的坐标

使用excel的过程,我们知道,根据一个坐标我们很容易直接找到当前坐标的值,但是如果知道一个坐标里的值,反过来求该点的坐标的话,据我所知,excel没有提供现成的函数供使用,所以需要自己用VBA编写函数使用...(代码来自互联网) Excel,ALT+F11打开VBA编辑环境,左边的“工程”处添加一个模块 把下列代码复制进去,然后关闭编辑器 Public Function iSeek(iRng As Range...iSeek了,从以上的代码可以看出,iSeek函数带三个参数,其中第一个和第二个参数制定搜索的范围,第三个参数指定搜索的内容,例如 iSeek(A1:P200,20),即可在A1与P200围成的二维数据表搜索值

8.6K20

文本、图片和按钮Flutter怎么用

而文本、图片和按钮,则是这些不同的UI框架构建视图都要用到的三个最基本的控件。 Flutter的文本Text和图片Image,我在前面的文章中都有过介绍,今天我们再来详细地聊一聊。...面对这样的需求,Android,我们使用 SpannableString来实现;iOS,我们使用NSAttributedString来实现;而在Flutter中国也有类似的概念,即TextSpan...这,和Android的ImageView、iOS的UIImageView的属性都是类似的,我Flutter的图片组件这篇文章中有做详细介绍。...首先, ImageProvider 根据 _ImageState 传递的图片配置,生成对应的图片缓存key,然后去ImageCache查找是否有对应的图片缓存,如果有,则通知 _ImageState...既然是按钮,因此除了控制基本样式之外,还需要响应用户点击行为。这就对应着按钮控件两个最重要的参数了: onPressed 参数用于设置点击回调,告诉Flutter在按钮点击时通知我们。

7.6K20

Docker Desktop 启用 K8s 服务

集群就劝退了很多的人,因此这里最简单的方式就是直接使用 Windows or Mac 上的 Docker Desktop 内置的 K8s 来学习 然而,由于某些网络原因,如果你直接在 Dokcer 启用这个功能的话...最新版的软件安装时也是会默认使用 WSL 作为宿主的,这里我使用的是 3.3.1 版本的 Docker,内置的 k8s 版本为 v1.19.7 PS:安装 Docker 之前需要你 BIOS 开启虚拟化...,同时基于你的宿主程序的选择,你还需要执行如下的操作 使用 WSL2 作为宿主:“控制面板\所有控制面板项\程序和功能”中选择“启用或者关闭 Windows 功能” 勾选上适用于 Linux 的 Windows...子系统,然后 Microsoft 商城中下载一个 Linux 的发行版本 使用 Hyper-V 作为宿主:“控制面板\所有控制面板项\程序和功能”中选择“启用或者关闭 Windows 功能” 勾选上...等待命令的执行完成,可以看到我们本地的 Docker 已经包含了 images.properties 文件列到的镜像 ?

3.8K21

NGINX根据用户真实IP限制访问

需求 需要根据用户的真实IP限制访问, 但是NGINX前边还有个F5, 导致deny指令不生效. 阻止用户的真实IP不是192.168.14.*和192.168.15.*的访问请求....} 说明如下: proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 获取请求头X-Forwarded-For的用户真实...allow 192.168.14.0/24; allow 192.168.15.0/24; deny all; 根据nginx官方文档, deny指令是根据" client address"进行限制的...解释如下: 关于$remote_addr: 是nginx与客户端进行TCP连接过程,获得的客户端真实地址....但是实际场景,我们即使有代理,也需要将$remote_addr设置为真实的用户IP,以便记录在日志当中,当然nginx是有这个功能,但是需要编译的时候添加--with-http_realip_module

2.5K20

NGINX 根据用户真实 IP 进行限制

需求 需要根据用户的真实 IP 进行限制, 但是 NGINX 前边还有个 F5, 导致 deny 指令不生效....403; } 说明如下: •proxy_set_header X-Forwarded-For proxy_add_x_forwarded_for; 获取请求头 X-Forwarded-For 的用户真实...allow 192.168.14.0/24; allow 192.168.15.0/24; deny all; 根据nginx官方文档, deny 指令是根据「client address」进行限制的....address」对应的变量是: $remote_addr ✍️引用: $remote_addr: client address 关于 $remote_addr: 是 nginx 与客户端进行 TCP 连接过程,...但是实际某些特殊场景,我们即使有代理,也需要将 $remote_addr 设置为真实的用户 IP,以便记录在日志当中,当然 nginx 是有这个功能,但是需要编译的时候添加 --with-http_realip_module

2.4K30

dotnet 8 WPF 支持 RDP 远程桌面状态下启用渲染硬件加速

本文将和大家介绍 dotnet 8 里 WPF 引入的新功能之一, RDP 远程桌面状态下启用渲染硬件加速 dotnet 8 之前,在用户进行 RDP 远程桌面时 WPF 应用将默认关闭硬件渲染加速以获得更好的兼容性.../dotnet/wpf/issues/3215 由于 XP 已经过于考古且 dotnet 8 接近完全无法 XP 系统上运行,于是我就对此进行优化,请看 https://github.com/dotnet.../wpf/pull/7015 然而大佬们经过测试发现了一些额外的问题,且担心这个改动过于底层加上没有充分的测试,怕一些奇怪的设备上运行错误。...于是大佬重新提了 https://github.com/dotnet/wpf/pull/7684 用来提供配置的方式控制此功能,默认行为依然保持 RDP 远程桌面时 WPF 应用将关闭硬件渲染加速,依然使用软渲染方式...配置启用 RDP 远程桌面时使用硬件渲染加速功能才会生效 以下是配置启用 RDP 远程桌面时使用硬件渲染加速功能的方法,以下代码推荐放在 App 构造函数,否则将可能渲染线程已经跑起来导致配置无效

28210

Flutter 创建可拖动的浮动操作按钮

必须根据移动增量更新按钮的偏移量。 一个浮动的动作按钮通常可以点击时执行一个动作,所以我们添加一个名为onPressed( VoidCallback) 的参数作为参数。...通常,所需的行为是onPressed仅在点击按钮时调用回调,而不是拖动结束时调用。然而,当拖动结束时,指针向上事件也会被触发。作为解决方案,我们需要跟踪按钮是否被拖动。...所以,我们可以检查内部onPointerUpcallback 仅onPressed值为_isDraggingis 时调用回调false。 下面是用于创建可拖动浮动操作按钮的类。...还有一种方法_updatePosition可以根据移动增量更新当前偏移量。...基本上,您可以使用Listener小部件来检测指针移动事件并根据移动增量更新按钮偏移。该Listener小部件还支持检测应执行按钮操作的指针向上事件,除非它刚刚被拖动。

5.4K10

WPF 程序应用 Windows 10 真•亚克力效果

本文介绍如何在 WPF 程序应用 Windows 10 真•亚克力效果。(而不是一些流行的项目里面自己绘制的亚克力效果。)...---- API 需要使用的 API 是微软的文档并未公开的 SetWindowCompositionAttribute。...我另一篇博客中有介绍此 API 各种用法的效果,详见: 使用 SetWindowCompositionAttribute 来控制程序的窗口边框和背景(可以做 Acrylic 亚克力效果、模糊效果、主题色效果等...) - walterlv 当然,使用此 API 也可以做 Windows 10 早期的模糊效果,比如: Windows 10 上为 WPF 窗口添加模糊特效(就像开始菜单和操作中心那样) - walterlv...如何使用 为了方便地让你的窗口获得亚克力效果,我做了两层不同的 API: AcrylicBrush 当然,受到 Win32 启用亚克力效果的限制,只能在窗口上设置此属性 WindowAccentCompositor

30910

WPF 绑定命令 MVVM 的 CanExecute 和 Execute 在按钮点击都没触发可能的原因

WPF 推荐使用 MVVM 绑定命令,但是绑定命令会存在很多坑,其中一个就是焦点的问题。...如果在用户点击按钮的时候出现了焦点修改,那么此时的命令是不会被触发 命令绑定按钮点击的时候,会触发按钮拿到键盘焦点,此时其他元素如果之前有拿到焦点,那么会触发元素失去焦点。...如果在元素一次 Dispatcher 的过程重新拿到焦点,那么按钮的命令将不会被触发 说起来复杂,因为项目的代码是很复杂很难直接看到这个问题,所以我建议创建一个新的 WPF 项目,不要引用任何小伙伴框架...public ViewModel ViewModel { get; } = new ViewModel(); 如何绑定 ViewModel 请看 win10 uwp DataContext 界面放一个文本和一个按钮...,可以发现按钮的命令没有触发 命令的 CanExecute 打上断点,可以发现连 CanExecute 都没有进入 如果遇到了在按钮 MVVM 绑定命令,发现命令没有触发,同时 CanExecute

1.5K20
领券