利用VBA操作表单控件的移动

本文以按钮控件为例,分享如何利用VBA操作表单控件的移动,主要使用到Shape.IncrementLeft 以及IncrementTop 方法。

1.将多个单元格转为按钮控件

作为演示案例,我们先制作两个按钮控件。

首先,在A1单元格输入内容---“下移”,B1单元格输入内容---“右移”。然后,我们选中A1和B1单元格,执行以下代码,就将A1和B1单元格转为按钮控件,并完全填充单元格,同时设置按钮名称为其所在的单元格地址

图片

Sub 将多个单元格转为按钮()
    Dim rng As Range
    For Each rng In Application.Selection
        Dim btn As Button
        Set btn = ActiveSheet.Buttons.Add(rng.Left, rng.Top, rng.Width, rng.Height)
        With btn
            .Caption = rng.Value
            .Font.Size = 16
            .Font.Bold = True
            .Name = rng.Address
        End With
        rng.ClearContents
    Next
End Sub

2.右移按钮,指定宏---“右移”

图片

Sub 右移()
    Dim btn As Shape
    Set btn = ActiveSheet.Shapes(Application.Caller)
    btn.IncrementLeft Range(Application.Caller).Width
    btn.Name = btn.TopLeftCell.Address
End Sub

3.下移按钮,指定宏---“下移”

图片

Sub 下移()
    Dim btn As Shape
    Set btn = ActiveSheet.Shapes(Application.Caller)
    btn.IncrementTop Range(Application.Caller).Height
    btn.Name = btn.TopLeftCell.Address
End Sub
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值