MFC/C++学习系列之简单记录5

发布于:2024-12-22 ⋅ 阅读:(17) ⋅ 点赞:(0)

MFC/C++学习系列之简单记录5

  • 前言
  • 控件位置设置
    • 实际说明
      • C# Tab位置设定的相关使用
      • C++ MFC中Tab位置设定的相关使用
  • 总结


前言

需求提及不够清楚,没有详细的文档输入,甚至协议都是看代码,然后查文件才确认协议更改。这样对新来的开发人员很不友好。
工作这段时间真正体会到文档的重要性,哪怕是简单文件说明都好过几天看代码摸索!


控件位置设置

基于VC 6.0的MFC架构开发,但是最近需求不明确,以为界面要修改,研究了一下界面设计。
意图:在界面中设置Tab界面,Tab中插入很多MSFlexGrid表格。
问题来了,插入Tab很简单,拖动Tab就可以放置在界面上,而MSFlexGrid却始终无法在Tab中显示,要不就是整个覆盖掉Tab,要不就是不合适,也无法切换。
最后研究了别的源码设计才发现问题,原来VC 6.0中的Tab中要插入控件需要手动设置控件位置,假装控件在界面中出现。
这和VS C#的界面很不一样,在C#中的Tab增加控件,只需要使用“ Tab"按键,就可以把需要添加的控件拖动至Tab中,并且因为每个子Tab页面不同并不需要在显示一个Tab的控件时来隐藏另一个Tab界面的控件。

实际说明

C# Tab位置设定的相关使用

在这里插入图片描述
在VS 2019中直接在工具箱中找到TabControl控件,然后可以直接拖动DataGrid进入TabControl,不需要额外的设置。如果需要表格和TabControl的大小一致,也只需要鼠标拖动或者通过Margin来进行定义。而且前端界面的代码可以直接复制使用,省去了很多编辑的时间。

<TabControl x:Name="tabControl" HorizontalAlignment="Left" Height="250" Margin="175,100,0,0" VerticalAlignment="Top" Width="485">
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5">
                    <DataGrid x:Name="Datalist_Grid" ItemsSource="{Binding DataList}" 
                        ScrollViewer.VerticalScrollBarVisibility="Hidden" 
                        AutoGenerateColumns="False"
                        CanUserAddRows="False"
                        CanUserResizeColumns="False"
                          Margin="0,0,28,0"
                          >
                        <DataGrid.Columns>
                            <DataGridTextColumn Header="名称" Width="*" Binding="{Binding Name}"/>
                            <DataGridTextColumn Header="衣服类型" Width="*" Binding="{Binding ClothTpye}"/>
                            <DataGridTextColumn Header="颜色" Width="*" Binding="{Binding ClothColor}"/>
                            <DataGridTextColumn Header="尺码" Width="*" Binding="{Binding ClothSize}"/>
                            <DataGridTextColumn Header="价格" Width="*" Binding="{Binding ClothPrice}"/>

                            <DataGridTemplateColumn Header="操作" Width="50">
                                <DataGridTemplateColumn.CellTemplate>
                                    <DataTemplate>
                                        <StackPanel Orientation="Horizontal">
                                            <TextBlock><Hyperlink Command="{Binding DeleterData}" CommandParameter="{Binding}"><Run Text="操作"/></Hyperlink></TextBlock>
                                        </StackPanel>
                                    </DataTemplate>
                                </DataGridTemplateColumn.CellTemplate>
                            </DataGridTemplateColumn>
                        </DataGrid.Columns>
                    </DataGrid>
                </Grid>
            </TabItem>
        </TabControl>

C++ MFC中Tab位置设定的相关使用

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

CWnd* pTabWnd = pTabWnd=GetDlgItem(IDC_TAB1);
	if (pTabWnd != NULL)
	{
		// 获取Tab页的矩形区域
		CRect rect;
		pTabWnd->GetClientRect(&rect);
		pTabWnd->MoveWindow(rect);
		CRect btnrect(rect.left+50, rect.top+80, rect.left+100, rect.top + 100);
		// 设置按钮的位置和大小
		m_Btn1.MoveWindow(&btnrect, TRUE); // 将按钮移动到Tab页的矩形区域内
	}

这里是获取控件的位置,然后将获取的控件位置通过RECT的形式进行记录,记录好了之后需要在通过使用MoveWindow函数,你可以设置控件的位置和大小。CRect对象可以直接传递给MoveWindow函数。
而这里还仅是将按钮的位置写入了Tab中,每个Tab项中都存在按钮控件,而C#放入哪个Tab子控件就只存在该控件中,不会在其他界面显示,如果在其他界面中需要显示,只要复制一下就过去了。

神奇的来了,在MFC中如果想要达到C#界面中的效果,需要写代码实现。没错!你需要告诉电脑,这个控件在第一界面显示后,第二个界面就不能显示了哦!增加了开发人员的代码量!

void CMFCtest1Dlg::OnTcnSelchangeTab1(NMHDR* pNMHDR, LRESULT* pResult)
{
	// TODO: 在此添加控件通知处理程序代码
	*pResult = 0;
	LPNMLISTVIEW pNMListView = reinterpret_cast<LPNMLISTVIEW>(pNMHDR);

	// 根据选中的Tab页面,显示或隐藏按钮
	if (pNMListView->iItem == 0) // 如果选中的是第一个Tab页面
	{
		m_Btn1.ShowWindow(SW_SHOW); // 显示按钮
	}
	else
	{
		m_Btn1.ShowWindow(SW_HIDE); // 隐藏按钮
	}
}

总结

今天主要写了一下Tab控件中设置其他控件的方式,之前只是听说MFC很老,最近使用发现开发不够C#便捷,不知道是不是自己没有掌握到方法,继续基类吧!