VBA开发:如何防止ActiveX控件非预期移位或改变尺寸?

本文讲述了在VBA开发中,如何利用ActiveX控件的Placement属性来控制控件随单元格变化时的位置和尺寸。默认情况下,控件位置会改变但大小不变。为了保持位置和大小稳定,应将Placement属性设为3。对于高分辨率与低分辨率屏幕的兼容问题,文章提到了需要在Worksheet激活时重设控件属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        VBA开发应用时,经常用到ActiveX控件,比如按钮、文本框、下拉框等等。但是相信很多朋友会有一个困扰,那就是,可能本来界面设计得好好的,美观简洁。但是随着使用,控件的尺寸有的变大了,有的变小了,控件的位置也变乱了,有的移到左边,有的移到右边。整个界面非常难看。

        其实,在所有的ActiveX控件里,都有一个很重要的但是很容易被人忽视的属性Placement,这个属性的值,就决定着这个控件的位置或尺寸是否会随着单元格改变。

        下面是作者对这个属性的值的总结,

Placement属性值

含义

1

  1. 控件的位置会随着左上角所在单元格的移动而移动,
  2. 控件的宽度会随着控件跨越单元格的宽度改变而改变
  3. 控件的高度会随着控件跨越单元格的高度改变而改变

2

  1. 控件的位置会随着左上角所在单元格的移动而移动。
  2. 控件的宽度和高度保持固定不变。

3

控件的位置,宽度和高度保持不变

        找到了这个神奇的属性之后,咱们就可以根据需要来设置这个属性了。缺省的情况下,控件的Replacement属性初值为2,就是位置会改变,但是大小不会变。

        绝大部分情况下,程序设计者希望保持控件的位置和大小都不变,所以你知道应该怎么做了吧?把placement属性改为3,这样就基本能满足您的要求了。具体操作,如图1所示,在控件上点击右键,选择属性,然后修改Placement值就可以了。

        为什么我上面只说基本满足要求了呢?还有一种特殊情况,就是你设计程序时如果显示分辨率是高分辨率,到了低分辨率的屏幕上使用时,还是会出现一点小的问题。比如原来紧挨着的两个控件,中间会出现一点空格。

        这种情况我也是研究了好久,至今没找到特别简洁的方法来解决。目前的唯一解决方案是,每次Worksheet激活时,重设一下各个控件的Top,Height,Left,Width属性。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ZevieZ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值