VC中Microsoft FlexGrid控件的使用及合并单元格、可编辑操作

1. 给FlexGrid控件绑定成员变量:m_FlexGrid。

2. 设置行列数
              m_FlexGrid.SetCols(4);                  //设置列数
              m_FlexGrid.SetRows(6);                 //设置行数

3. 设置固定行数和固定列数
              m_FlexGrid.SetFixedRows(1);         //设置固定行数为1行
              m_FlexGrid.SetFixedCols(0);          //设置固定列数为0列

4. 设置列宽、行高
             m_FlexGrid.SetColWidth(1,1500);        //设置列号为1的列宽为1500
             m_FlexGrid.SetRowHeight(2,300);       //设置行号为2的行高为300

5. 设置文本对齐方式
             m_FlexGrid.SetColAlignment(1,4);        //设置列号为1的文本对齐方式

    参数对应描述为:
             0   单元内容顶部左对齐。
             1   单元内容中间左对齐。对字符串的缺省设置值。
             2   单元内容底部左对齐。
             3   单元内容顶部居中。
             4   单元内容中间居中。
             5   单元内容底部居中。
             6   单元内容顶部右对齐。
             7   单元内容中间右对齐。对数字的缺省设置值。
             8   单元内容底部右对齐。
              9   单元内容一般对齐方式。对字符串中间左对齐而对数值中间右对齐。

6. 设置表头和单元格内容
             m_FlexGrid.SetTextArray(0,"Head1");                 //设置表头(第1列)内容为“Head1”
             m_FlexGrid.SetTextMatrix(1,1,"Text");                //设置单元格(行号1列号1)内容为“Text”

7. 增加一行
             m_FlexGrid.AddItem("AddString",(COleVariant)(3L));           //在行号为3的位置增加一行

8. 合并单元格
             for(i=0;i<4;i++)
                     m_FlexGrid.SetTextMatrix(5,i,"合计");        //将行号为5、列号从0到4的单元格内容设为相同“合计”
             m_FlexGrid.SetMergeCells(2);                           //设置单元格合并方式(下述)
             m_FlexGrid.SetMergeRow(5,TRUE);                 //设置要合并的行

      SetMergeCells函数的参数值如下:
             0: flexMergeNever                              默认的选项,就是不合并
             1: flexMergeFree                                不规则的合并
             2: flexMergeRestrictRows                   行合并
             3: flexMergeRestrictColumns              列合并
             4: flexMergeRestrictBoth                     行,列都合并

     注意只有单元格内容相同时才能进行合并操作。

9. 制作可编辑的FlexGrid控件

    放置一个Edit控件,绑定成员变量为m_Edit,并设置初始状态为不可见。

    响应FlexGrid控件的Click事件:

              void CBlackBKDlg::OnClickMsflexgrid()
              {
                     long lCol=m_FlexGrid.GetColSel();         //获取点击的行号
                     long lRow=m_FlexGrid.GetRowSel();      //获取点击的列号
                     if(lRow>m_FlexGrid.GetRows() || lRow==0)              //判断点击是否有效
                               return;

                      CRect rect;
                     m_FlexGrid.GetWindowRect(&rect);                 //获取FlexGrid控件的窗口矩形
                     ScreenToClient(&rect);                                    //转换为客户区矩形
                      CDC* pDC=GetDC();
                      //MSFlexGrid 控件的函数的长度单位是“缇(twips)”,需要将其转化为像素,1440 缇 = 1 英寸
                      //计算象素点和缇的转换比例
                       int nTwipsPerDotX=1440/pDC->GetDeviceCaps(LOGPIXELSX);
                     int nTwipsPerDotY=1440/pDC->GetDeviceCaps(LOGPIXELSY);
                      //计算选中格的左上角的坐标(象素为单位)
                      long y = m_FlexGrid.GetRowPos(lRow)/nTwipsPerDotY;
                       long x = m_FlexGrid.GetColPos(lCol)/nTwipsPerDotX;
                      //计算选中格的尺寸(象素为单位)。加1是实际调试中,发现加1后效果更好
                       long width = m_FlexGrid.GetColWidth(lCol)/nTwipsPerDotX+1;
                       long height = m_FlexGrid.GetRowHeight(lRow)/nTwipsPerDotY+1;
                      //形成选中个所在的矩形区域
                       CRect rc(x,y,x+width,y+height);
                      //转换成相对对话框的坐标
                       rc.OffsetRect(rect.left+1,rect.top+1);

                       CString strValue=m_FlexGrid.GetTextMatrix(lRow,lCol);               //获取单元格内容

                      m_Edit.ShowWindow(SW_SHOW);                         //显示控件
                      m_Edit.MoveWindow(rc);                                        //改变大小并移到选中格位置
                       m_Edit.SetWindowText(strValue);                           //显示文本
                       m_Edit.SetFocus();                                                 //获取焦点
             }

      编辑完成释放焦点之后,将数据写回单元格。响应Edit控件的EN_KILLFOCUS事件:

             void CBlackBKDlg::OnKillfocusEditChange()
            {
                     CString strInput;
                    GetDlgItemText(IDC_EDIT_CHANGE,strInput);      //获取输入框内容
                     m_FlexGrid.SetText(strInput);                                //设置单元格内容
                    m_Edit.ShowWindow(SW_HIDE);                           //隐藏输入框
             }

posted @ 2010-05-25 10:48  逆时针  阅读(8303)  评论(0编辑  收藏  举报