当前位置: 首页 > news >正文

ARCGIS PRO SDK ProWindow自定义窗口DataGrid控件的应用

    ProWindow 是ArcGIS Pro SDK中用于创建自定义窗口的关键类,帮助开发者扩展ArcGIS Pro的功能和用户界面。这些窗口可以嵌入到ArcGIS Pro的主界面中,提供与核心功能的无缝集成。

创建一个窗体xml:

controls:ProWindow
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:controls="clr-namespace:ArcGIS.Desktop.Framework.Controls;assembly=ArcGIS.Desktop.Framework"
        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:extensions="clr-namespace:ArcGIS.Desktop.Extensions;assembly=ArcGIS.Desktop.Extensions"
        xmlns:VisualBasic="clr-namespace:Microsoft.VisualBasic;assembly=Microsoft.VisualBasic.Core" x:Class="ProWindow1"
        mc:Ignorable="d"
        Title="绘制图例" Height="320" Width="530" 
        WindowStartupLocation="CenterOwner"
    >
    <controls:ProWindow.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
                <extensions:DesignOnlyResourceDictionary Source="pack://application:,,,/ArcGIS.Desktop.Framework;component\Themes\Default.xaml"/>
            </ResourceDictionary.MergedDictionaries>
        </ResourceDictionary>
    </controls:ProWindow.Resources>
    <Grid>
        <GroupBox Header="地图图层" FontSize="10" HorizontalAlignment="Left" VerticalAlignment="Top" Width="225" Height="250 " Margin="3,0,0,0">
            <StackPanel>
                <DataGrid x:Name="DataGrid1" FontSize="9" AutoGenerateColumns="False" ScrollViewer.VerticalScrollBarVisibility="Visible"  HorizontalAlignment="Left" VerticalAlignment="Top" Width="210" Height="230 " Margin="2,0,0,0">
                    <DataGrid.Columns>
                        <DataGridTextColumn Header="图层名称" Width="85" Binding="{Binding tc_name, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                        <DataGridCheckBoxColumn Header="参与?" Width="35"  Binding="{Binding sf_cy}"/>
                        <DataGridTemplateColumn Header="字段名称" Width="65">
                            <DataGridTemplateColumn.CellTemplate >
                                <DataTemplate>
                                    <ComboBox ItemsSource="{Binding AvailableCategories}"
                                              DisplayMemberPath="zd_Namea"
                                              SelectedValuePath="zd_ID"
                                              SelectedValue="{Binding zd_nameID ,Mode=TwoWay , UpdateSourceTrigger=PropertyChanged}" /> 
                                </DataTemplate>
                            </DataGridTemplateColumn.CellTemplate>
                        </DataGridTemplateColumn>
                    </DataGrid.Columns>
                    <!-- 标头居中 -->
                    <DataGrid.ColumnHeaderStyle>
                        <Style TargetType="{x:Type DataGridColumnHeader}">
                            <Setter Property="HorizontalContentAlignment" Value="Center"/>
                        </Style>
                    </DataGrid.ColumnHeaderStyle>
                </DataGrid>
            </StackPanel>
        </GroupBox>
        <Button x:Name="Button1" FontSize="9" Content="获取图层" Height="18" Width="45" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="78,257,0,0" />
    </Grid>
</controls:ProWindow>

允许效果:

设置DataGrid表字段名称列为下拉框,DataGridTemplateColumn  设置ComboBox动态绑定。

vb.net  ,定义Person1类,用于DataGrid1设置数据源类型

Imports System.Collections.ObjectModel
Public Class Person1                '用于DataGrid1设置数据源
    Public Property tc_name As String
    Public Property sf_cy As Boolean
    Public Property zd_name As String
    Public Property zd_nameID As Integer ' 用于绑定选中的 zd_name
    Public Property AvailableCategories As List(Of Zd_name)
    Public Sub New(tc_name As String, sf_cy As Boolean, zd_name As String, zd_nameID As Integer, AvailableCategories As List(Of Zd_name))
        Me.tc_name = tc_name
        Me.sf_cy = sf_cy
        Me.zd_name = zd_name
        Me.zd_nameID = zd_nameID
        Me.AvailableCategories = AvailableCategories
    End Sub
End Class

定义ComboBox动态绑定类

Public Class Zd_name
    Public Property zd_ID As Integer
    Public Property zd_Namea As String
End Class

在窗体类中

Public Class ProWindow1
    Inherits ArcGIS.Desktop.Framework.Controls.ProWindow
    Private people_1 As New ObservableCollection(Of Person1)()
    Public Property Categories As ObservableCollection(Of Zd_name)
    Public Sub New()
           InitializeComponent()
           DataGrid1.ItemsSource = people_1
    End Sub
    Dim pmap As Map
    Dim dict(50) As List(Of FieldDescription)
    Dim pFeatureLayer As FeatureLayer
    Dim pFeature As Feature
    Dim PFeatureClass As FeatureClass
    Dim pFeatCursor As RowCursor
    Private Async Sub Button1_Click(sender As Object, e As RoutedEventArgs) Handles Button1.Click
        Dim pMapView As MapView = MapView.Active
        Dim collection As ObservableCollection(Of Person1) = DirectCast(DataGrid1.ItemsSource, ObservableCollection(Of Person1))
        Dim jsq As Integer = -1

        If collection IsNot Nothing Then
            collection.Clear()  ' 直接清空集合
        End If
        DataGrid1.CanUserAddRows = True  '将CanUserAddRows重新设置为True,这样DataGrid就会自动生成新行,我们就能在新行中输入数据了。
        If pMapView Is Nothing = True Then
            MsgBox("当前打开的不是激活的地图.")
            Exit Sub
        End If
        Dim pmap As Map = pMapView.Map
        Dim categories(100) As List(Of Zd_name)
        Dim jsq1 As Integer = 0
        For i = 0 To pmap.Layers.Count - 1
            If pmap.Layers(i).GetType.Name = "FeatureLayer" Then
                jsq += 1
                pFeatureLayer = pmap.Layers(i)
                dict(jsq) = New List(Of FieldDescription)
                Await QueuedTask.Run(Sub()
                                         dict(jsq) = pFeatureLayer.GetFieldDescriptions
                                     End Sub)
                jsq1 = 0
                categories(jsq) = New List(Of Zd_name)
                For Each ttsr In dict(jsq)
                    jsq1 += 1
                    categories(jsq).Add(New Zd_name() With {.zd_ID = jsq1, .zd_Namea = ttsr.Name})
                Next
                people_1.Add(New Person1(pmap.Layers(i).Name, False, "", 1, categories(jsq)))
            End If
        Next
        DataGrid1.ItemsSource = people_1
    End Sub
End Class

运行结果:

读取DataGrid表:vb.net

        Dim tc_mc As String
        Dim tc_cy As Boolean
        Dim zd_id As Integer = 0
        Dim tc_zd As String
        Dim tc_zdZ() As String
        Dim zdzs As Integer
        Dim tl_id As Integer = 0
        For Each row As Person1 In DataGrid1.Items
             tc_mc = row.tc_name          ' DataGrid第一列
             tc_cy = row.sf_cy            ' DataGrid第二列
             zd_id = row.zd_nameID        ' DataGrid第三列  :ComboBox选中的ID
             tc_zd = GetCategoryNameByID(zd_id, row.AvailableCategories)  'ComboBox下拉框元素集合
        next

自定义函数:

Private Function GetCategoryNameByID(categoryID As Integer, categories As List(Of Zd_name)) As String
    Dim category As Zd_name = categories.FirstOrDefault(Function(c) c.zd_ID = categoryID)
    Return If(category IsNot Nothing, category.zd_Namea, "Unknown")
End Function

相关文章:

  • langchain-ollama的ragflow简单实现
  • 车载以太网网络测试 -23【TCPUDP通信示例】
  • 模糊规则激活方法详解(python实例对比)
  • 【Tauri2】001——安装及运行
  • shadcn如何给dialog增加关闭按钮和隐藏右上角关闭按钮
  • 重写ring3 API函数
  • 安宝特应用 | 军工级数据安全赋能保密产品数字化交付
  • 第五章 动态规划
  • Linux文件描述符及重定向
  • 26考研——图_图的存储(6)
  • Python学习笔记(6)
  • 在计算进程D状态持续时间及等IO的时间遇到的一处问题
  • Resource usage
  • Flink 流处理框架的核心特性
  • PostgreSQL 连接数超限问题
  • 流程控制语句
  • 每日总结3.24
  • C/C++蓝桥杯算法真题打卡(Day10)
  • 刷刷刷刷刷
  • iPhone 16如何翻译文档?文档翻译技巧、软件推荐
  • 中华人民共和国和俄罗斯联邦在纪念中国人民抗日战争、苏联伟大卫国战争胜利和联合国成立80周年之际关于进一步深化中俄新时代全面战略协作伙伴关系的联合声明
  • 本科生已发14篇SCI论文被指由其教授父亲挂名,重庆大学成立工作组核实
  • 南通市委常委、市委秘书长童剑跨市调任常州市委常委、组织部部长
  • 明星站台“胖都来”背后:百元起录视频,20万可请顶流
  • 探索人类的心灵这件事,永远也不会过时
  • 退休11年后,71岁四川厅官杨家卷被查