【ArcGIS Pro二次开发】(3):UI管理_显示隐藏Tab、Group、Control等控件

该文章介绍了如何在ArcGISPro中进行UI管理,包括添加和控制选项卡、组及按钮的显示与隐藏。通过条件控制和重写按钮事件,实现了对【显示按钮】、【显示选项卡】和【显示组】的动态管理,展示了ArcGISPro的自定义功能。

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

在ArcGIS Pro工作中,有时候会涉及到工具栏UI的管理,比如,打开模型构建器时,工具栏才会出现新的选项卡(Tab)【ModelBuilder】,工程未做更改,则【保存】按钮显示灰色不可用。

下面以一个小例子来学习一下。


一、新建项目,并添加示例用的控件

1、新建一个项目,命名为【UIManager】,再添加4个ArcGIS Pro 按钮【Show_Button、Show_Tab、Show_Group、Test_Button】。具体操作可以参考我的上一篇笔记:

【ArcGIS Pro二次开发】(2):创建一个Add-in项目https://blog.youkuaiyun.com/xcc34452366/article/details/128985113?spm=1001.2014.3001.5501

2、更新Config.daml文件的</modules>模块,添加2个Tab【UI管理器、示例选项卡】,并把4个按钮分为2组【UI管理组、示例组】。更新后的</modules>代码如下:

<modules>
    <insertModule id="UIManager_Module" className="Module1" autoLoad="false" caption="Module1">
      <!-- 选项卡-->
      <tabs>
        <!-- UI管理选项卡,下面2个组-->
        <tab id="UIManager_Tab_UI" caption="UI管理器">
          <group refID="UIManager_Group_UI"/>
          <group refID="UIManager_Group_Test"/>
        <!-- 示例选项卡-->
        </tab>
        <tab id="UIManager_Tab_Test" caption="示例选项卡">
        </tab>
      </tabs>
      <!-- 组-->
      <groups>
        <!-- UI管理组,下面3个管理按钮-->
        <group id="UIManager_Group_UI" caption="UI管理组" appearsOnAddInTab="false">
          <button refID="UIManager_Show_Button" size="large" />
          <button refID="UIManager_Show_Tab" size="large" />
          <button refID="UIManager_Show_Group" size="large" />
        </group>
        <!-- 示例组,下面1个示例按钮-->
        <group id="UIManager_Group_Test" caption="示例组" appearsOnAddInTab="false">
          <button refID="UIManager_Test_Button" size="large" />
        </group>
      </groups>
      <!-- 控件-->
      <controls>
        <!-- 【Button】显示按钮-->
        <button id="UIManager_Show_Button" caption="显示按钮" className="Show_Button" loadOnClick="true" smallImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue16.png" largeImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue32.png">
          <tooltip heading="Tooltip Heading">Tooltip text<disabledText /></tooltip>
        </button>
        <!-- 【Button】显示选项卡-->
        <button id="UIManager_Show_Tab" caption="显示选项卡" className="Show_Tab" loadOnClick="true" smallImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue16.png" largeImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue32.png">
          <tooltip heading="Tooltip Heading">Tooltip text<disabledText /></tooltip>
        </button>
        <!-- 【Button】显示组-->
        <button id="UIManager_Show_Group" caption="显示组" className="Show_Group" loadOnClick="true" smallImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue16.png" largeImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue32.png">
          <tooltip heading="Tooltip Heading">Tooltip text<disabledText /></tooltip>
        </button>
        <!-- 【Button】示例按钮-->
        <button id="UIManager_Test_Button" caption="示例按钮" className="Test_Button" loadOnClick="true" smallImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue16.png" largeImage="pack://application:,,,/ArcGIS.Desktop.Resources;component/Images/GenericButtonBlue32.png">
          <tooltip heading="Tooltip Heading">Tooltip text<disabledText /></tooltip>
        </button>
      </controls>
    </insertModule>
  </modules>

调试效果如下图:


二、添加条件控制

1、在</AddInInfo>模块和</modules>模块之间插入以下代码,目的是添加3个条件控制,分别控制【示例选项卡、示例组和2个显示按钮】的显示和隐藏:

<conditions>
    <!-- 条件控制器 -->
    <insertCondition id="Manager_ShowButton" caption="显示按钮">
      <!-- Manager_ShowButton的结果(True or False)会受到下面这个state的影响 -->
      <!-- 控制按钮显示 -->
      <state id="button_state" />
    </insertCondition>
    <insertCondition id="Manager_ShowTab" caption="显示选项卡">
      <!-- 控制选项卡显示 -->
      <state id="tab_state" />
    </insertCondition>
    <insertCondition id="Manager_ShowGroup" caption="显示组">
      <!-- 控制组显示 -->
      <state id="group_state" />
    </insertCondition>
  </conditions>

2、在要执行显示、隐藏的控件里增加condition属性,并把上面</conditions>模块里相对应的id赋给它。

3、打开【Module1.cs】,在Overrides行的下面添加如下代码,调用系统监听:

public static void StateCotroller(string stateID)
        {
            if (FrameworkApplication.State.Contains(stateID))
            {
                FrameworkApplication.State.Deactivate(stateID);
            }
            else
            {
                FrameworkApplication.State.Activate(stateID);
            }
        }

三、重写按钮的OnClick事件,调用控制器

分别打开【Show_Button.cs、Show_Tab.cs、Show_Group.cs】3个文件,分别重写OnClick事件,代码如下:

Module1.StateCotroller("button_state");
Module1.StateCotroller("tab_state");
Module1.StateCotroller("group_state");

四、调试

点击工具栏的【调试】按钮打开的ArcGIS Pro界面如下,默认情况下,示例选项卡、示例组被隐藏,2个显示按钮被禁用:

点示【显示按钮】,则右边2个按钮变为可用,再次点击,则禁用。

点示被启用的【显示选项卡】,则选项卡界面上出现一个【示例选项卡】,再次点击,则隐藏。

点示被启用的【显示组】,则出现一个【示例组】,再次点击,则隐藏。

以上就是这个小例子的全部效果。


五、工程文件分享

最后,放上工程文件的链接:

UIManagerhttps://pan.baidu.com/s/1EEBSWmTuRGbgwMys99e5xw?pwd=r023

PowerMock是一个为Java开发的测试框架,可以用于对那些在传统JUnit或TestNG测试框架中不容易进行测试的代码进行测试。但是,有时候我们会遇到“PowerMock not prepared for test”的问题。 当我们在使用PowerMock进行测试时,需要对被测试的类或方法进行一些准备工作,以便PowerMock能够正确地进行模拟和操作。如果没有正确地准备被测试的类或方法,就会出现"PowerMock not prepared for test"的错误。 造成这个问题的原因可能有几种。首先,可能是因为我们没有正确地使用PowerMock的注解或方法来准备被测试的类或方法。例如,@RunWith和@PrepareForTest注解可以被用来准备被测试的类或方法。 另外,可能是我们没有正确地配置测试环境。PowerMock需要在测试环境中正确设置一些参数和选项,以便能够正常工作。例如,可能需要确保正确引入PowerMock的相关依赖包,并将PowerMock的相关配置文件放置在正确的位置。 最后,可能是因为我们正在尝试使用PowerMock测试不适合被PowerMock处理的代码。PowerMock并不是适用于所有场景的,有些代码可能需要使用其他的测试方法或框架来进行测试。 为了解决"PowerMock not prepared for test"的问题,我们应该仔细检查测试代码,确保正确地使用了PowerMock的注解和方法;同时,我们还需要在测试环境中正确配置PowerMock的参数和选项;最重要的是,我们应该确认我们正在尝试使用PowerMock处理适合的代码。 总之,“PowerMock not prepared for test”问题的解决方法就是正确地准备被测试的类或方法,并正确地配置和使用PowerMock的相关功能。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

规划GIS会

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

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

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

打赏作者

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

抵扣说明:

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

余额充值