利用mfc编写activex控件

介绍:
       
利用vc中的向导来建立activex控件很方便。这篇文章不许备告诉activex的原理,它将一步步的告诉你如何创建一个简单的activex控件,其中主要介绍事件和属性页的编程,若是想知道其中的道理,我想你还须要读一些相关的书籍。本文是讲述mfc建立activex控件,若是想学习atl建立activex,请不要看此文。

编程

建立控件函数

  1. 使用向导创建activex control工程工具

  2. 选择file中的new,而后选择MFC ActiveX Control Wizard学习

  3. 输入工程的名称测试

  4. 选中全部的默认设置点击next字体

  5. 若是想子类话的话能够从combobox中选择相应的类ui

  6. 点击结束按钮完成。此时产生以下代码spa

    • C**App - 派生自 COleControlModule.  这个类提供了控件类的初始化initialization (InitInstance 销毁代码(ExitInstance).code

    • C**Ctrl - 派生自COleControl 提供控件的大部分功能,这个类是你须要编写大部分代码的部orm

    • C**PropPage - C**PropPage, (派生自 COlePropertyPage)。这个类主要操纵控件的属性页

编译控件,将生成.ocx的文件。这是vc自带的测试控件的容器将帮助咱们来测试控件。点击tool->activex control test container。在container中的工具栏中点击new control 咱们选取咱们刚才创建的工程好比smaple,咱们会发现其中画了一个椭圆。以下图。     

事件:

 

咱们在使用mfc的控件会发现控件会提供一些事件,最简单的例子是按钮这种控件提供click事件,也就是当用户点击按钮的时候会进行一些用户自定义的处理过程,这就是最简单的控件事件。Activex既然是一种控件,那么要想使其功能丰富天然少不了事件的支持。

Activex控件中有两种事件,一种是stock即系统定义的事件,一种是custom也就是用户自定义的事件。让咱们首先来看看stock事件如何处理。

Stock:

1.      点击classwiardactivex events属性页

2.      点击add event…按钮

3.      咱们若是从extanal name中选取已有的就是stock事件,也就是系统定义好的,固然咱们须要在下面选择stock,不能选择custom。咱们在这里选择Dblstock

4.      结束

这时咱们就建立了一个stock的事件,也就是双击事件。咱们来测试一下。

选择tool->activex control test container,而后在控件上双击就会发现下面会打印处双击消息,也就是控件响应了咱们的双击



custom:


下面咱们介绍如何定义用户自定义事件

咱们想完成如下功能,若是用户鼠标在圆或者椭圆内作的点击操做则触发一个事件。

1.classwiardactivex events属性页

2.点击add event…按钮

3.exteranl name里面填写ClickIn

4.结束

如今咱们就定义好了这个事件。关键是咱们要考虑如何触发这个事件。也就是当咱们在圆或者椭圆内单击鼠标左键的时候要触发这个事件。这里咱们能够想到要添加一个lbuttondown消息。

1.Classwizrd中肯定选择CSampleCtrl

2.添加消息WM_LBUTTONDOWN

3.结束

在类CsampleCtrl添加一个成员函数BOOL CSample3Ctrl::InCircle(CPoint& point)

函数内容以下:

CRect rc;

            GetClientRect(rc);

            // Determine radii

            double a = (rc.right - rc.left) / 2;

            double b = (rc.bottom - rc.top) / 2;

            // Determine x, y

            double x = point.x - (rc.left + rc.right) / 2;

            double y = point.y - (rc.top + rc.bottom) / 2;

            // Apply ellipse formula

            return ((x * x) / (a * a) + (y * y) / (b * b) <= 1);

        

    而后编译LBUTTONDOWN的响应函数

        void CCirc3Ctrl::OnLButtonDblClk(UINT nFlags, CPoint point)

        {

                    // Flash the color of the control if within the ellipse.

                    if (InCircle(point))

                    {

                            FireClickIn();

                    }

                    COleControl::OnLButtonDblClk(nFlags, point);

        }

    到这里咱们就完成ClickIn事件的编写和响应过程,让咱们来测试一下。


咱们能够添加一些画图操做来使得事件表现得更明显,更改代码以下:

static int i = 0;

            if (InCircle(point))

            {

                        FireClickIn();

                        CString num;

                        CBrush brush;

                        CDC* pDC = GetDC();

                        CRect rt;

                        GetClientRect(rt);

                        CRgn rgn;

                        rgn.CreateEllipticRgnIndirect(rt);

                        num.Format("%d", j);

                        brush.CreateSolidBrush(RGB(0, 0, 255));

                        pDC->FillRgn(&rgn, &brush);

                        pDC->SetBkMode(TRANSPARENT);

                        pDC->TextOut((rt.left + rt.right) / 2, (rt.top + rt.bottom) / 2, num);

            }


这样每一次点击都会在圆或者椭圆中间输出点击的累计次数。到这里咱们已经简单的介绍了在利用mfc编写activex控件的事件的处理,下面咱们看看activex控件的属性页编程。

 

属性页:

在咱们利用mfc提供的控件中咱们能够设置一些属性来改变控件的表现形式,仍是拿按钮举例,按钮属性当中有visible这个选项,咱们能够经过设置这个属性来改变按钮是否可见。下面咱们就看看activex控件的属性页编程。

属性页分为两种,一种是系统内建的属性页,好比说背景色,字体等;一种是用户自定义的属性页。咱们首先来看系统内建的属性页,在这里咱们来设置背景色

stock属性页

1.classwizard中的automation中点击add property,而后从external name中选择BackColorForeColor

2.CSampleCtrl.CPP文件中更改代码

BEGIN_PROPPAGEIDS(CSampleCtrl, 1)

            PROPPAGEID(CLSID_CColorPropPage)

END_PROPPAGEIDS(CSampleCtrl)

而后测试以下


custom属性页:

1.建立一个对话框资源(size 250x62 or 250x110 dialog units)或者在创建对话框中选择insert而后选择对话框中的IDD_OLE_PROPPAGE_SMALL就能够了。

2.而后双击该对话框建立新的类,取名CmyProperty,基类选择ColePropertyPate。

3.而后在该对话框上放置一个checkbox控件,取名Erase。

4.在classwiard中的automaition中选择add property(CSampleCtrl)external name 填erase,类型选择BOOL其它默认,implement选择member variable。

5.在classwizard中选择类CmyProperty,而后为checkbox添加成员变量。变量名为m_bErase,类型BOOL,optinal property name填写刚才新添加的用户自定义的属性名Erase。

6.在资源的string table中添加两个string一个是新建属性页的标题一个是新建属性页的名字,在这里咱们咱们设置的值是IDS_PPG_OPTIONS(options)和IDS_PPG_OPTIONS_CAPTION(caption)固然这个用户能够自行修改。

7.更改CmyProperty的cpp文件以下:

    

BOOL CMyProperty::CMyPropertyFactory::UpdateRegistry(BOOL bRegister)

{

   if (bRegister)
        return AfxOleRegisterPropertyPageClass(AfxGetInstanceHandle(),m_clsid,IDS_PPG_OPTIONS);

   else

         return AfxOleUnregisterClass(m_clsid, NULL);

}

CMyProperty::CMyProperty() :

   COlePropertyPage(IDD, IDS_PPG_OPTIONS_CAPTION)

{

   //{{AFX_DATA_INIT(CMyProperty)

   m_bErase = FALSE;

   //}}AFX_DATA_INIT

}

8.最后在CSampleCtrl的cpp文件中修改以下代码:

BEGIN_PROPPAGEIDS(CSampleCtrl, 2)

   PROPPAGEID(CLSID_CColorPropPage)

   PROPPAGEID(CMyProperty::guid)

END_PROPPAGEIDS(CSampleCtrl)

记住必定要把计数从1改成2,同时添加#include "myproperty.h"

9.在CSampleCtrl中修改以下代码

         void CSampleCtrl::DoPropExchange(CPropExchange* pPX)
         {
                  ExchangeVersion(pPX, MAKELONG(_wVerMinor, _wVerMajor));
                  COleControl::DoPropExchange(pPX);
                  PX_Bool(pPX, _T("Erase"), FALSE);
         }
         void CSampleCtrl::OnEraseChanged()
         {
                  InvalidateControl();
                  SetModifiedFlag();
         }
        void CSampleCtrl::OnDraw(CDC* pdc, const CRect& rcBounds, const CRect& rcInvalid)
               
        {
             pdc->FillRect(rcBounds, CBrush::FromHandle((HBRUSH)GetStockObject(WHITE_BRUSH)));
         
             CBrush bkBrush(TranslateColor(GetBackColor()));
             pdc->FillRect(rcBounds, &bkBrush);
         

             if (m_erase)
             {
                     pdc->MoveTo(rcBounds.left, (rcBounds.top + rcBounds.bottom) / 2);
                     pdc->LineTo(rcBounds.right, (rcBounds.top + rcBounds.bottom) / 2);
             }
             pdc->Ellipse(rcBounds);
 
        }

到这里基本完成了咱们的控件,也展现了activex控件事件和属性页的编程。Enjoy it.
相关文章
相关标签/搜索