winform 快捷键 切换tableControl 的tabPage

假设tableControl中有两个tabPage

用Ctrl + 1(小键盘)   和 Ctrl +2 (小键盘)


设置窗体 的 KeyPreview  = true


在窗体的 KeyDown事件中写 入代码:


 private void Form1_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.Control)
            {
                if (e.KeyCode == Keys.NumPad1)
                {
                    this.tabMain.SelectedIndex = 0;
                }
                else if (e.KeyCode == Keys.NumPad2)
                {
                    this.tabMain.SelectedIndex = 1;
                }
            }
        }





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WinForm TabControl 默认不支持切换动画,但是我们可以通过编写自定义控件来实现这一功能。以下是实现 WinForm TabPage 切换动画的一种方式: 1. 创建一个自定义控件类,继承 TabControl 控件; 2. 添加一个成员变量,用于存储当前激活的 TabPage 索引; 3. 重载 OnSelecting 方法,在该方法中记录当前激活的 TabPage 索引; 4. 重载 OnPaint 方法,在该方法中根据当前激活的 TabPage 索引绘制动画效果。 示例代码如下: ```csharp public class AnimatedTabControl : TabControl { private int _lastSelectedIndex = -1; protected override void OnSelecting(TabControlCancelEventArgs e) { base.OnSelecting(e); // 记录当前激活的 TabPage 索引 _lastSelectedIndex = SelectedIndex; } protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); if (_lastSelectedIndex == -1 || SelectedIndex == _lastSelectedIndex) return; // 获取当前激活的 TabPage 和上一次激活的 TabPage var currentTabPage = SelectedTab; var lastTabPage = TabPages[_lastSelectedIndex]; // 计算动画效果的参数 var direction = SelectedIndex > _lastSelectedIndex ? 1 : -1; var width = Width; var height = Height; var currentStartX = direction > 0 ? width : -width; var lastEndX = direction > 0 ? -width : width; // 绘制动画 using (var currentBitmap = new Bitmap(width, height, e.Graphics)) using (var lastBitmap = new Bitmap(width, height, e.Graphics)) using (var currentGraphics = Graphics.FromImage(currentBitmap)) using (var lastGraphics = Graphics.FromImage(lastBitmap)) { currentGraphics.SetClip(currentTabPage.Bounds); lastGraphics.SetClip(lastTabPage.Bounds); // 绘制当前激活的 TabPage currentGraphics.TranslateTransform(currentStartX, 0); InvokePaint(currentGraphics, currentTabPage); e.Graphics.DrawImage(currentBitmap, 0, 0); // 绘制上一次激活的 TabPage lastGraphics.TranslateTransform(lastEndX, 0); InvokePaint(lastGraphics, lastTabPage); e.Graphics.DrawImage(lastBitmap, 0, 0); } // 重置激活状态 _lastSelectedIndex = SelectedIndex; } } ``` 使用该自定义控件时,只需将原来的 TabControl 替换为 AnimatedTabControl 即可: ```csharp var animatedTabControl = new AnimatedTabControl(); animatedTabControl.TabPages.Add(new TabPage("Tab 1")); animatedTabControl.TabPages.Add(new TabPage("Tab 2")); animatedTabControl.TabPages.Add(new TabPage("Tab 3")); ``` 这样,当用户切换 TabPage 时,就会出现从右到左或从左到右的动画效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安得权

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值