zoukankan      html  css  js  c++  java
  • Installshield系列(三) 自定义窗口

    使用的是Install MSI Project

    (1)新建一个Dialog。

    InstallShield ->Installation Designer->User Interface->Diaglogs->All Dialogs->使用各种方法新建一个Dialog(直接New或者Import)

    (2)写自定义函数

       

     脚本

    #include "sqlhelper.rul"    //导入其他脚本函数
    #define DLG_MYDLG "SdCheckHytIndustry"  //SdCheckHytIndustry是我们的对话框名字
    #define btnTestConn 1302      //测试按钮  
    #define Server 1307           //服务器地址    
    #define DataBaseName 1308     //数据库名   
    #define UserName 1309         //用户名
    #define Password 1310         //密码 
    prototype NUMBER SetMidDataBase( BYREF STRING, BYREF STRING, BYREF STRING, BYREF STRING); 
    function NUMBER SetMidDataBase(svServer,svDatabaseName,svUserName,svPwd)
         HWND    hDlg,hwndItem,hwndDlg,hwndItemTest;      
         NUMBER nId, nResult; 
        NUMBER nControl,nMessage;
        BOOL bDone;  
        string msg,szPwd;
    begin  
          // ensure general initialization is complete
               if (!bSdInit) then
                  SdInit( );
               endif;
        //初始对话框函数
         if (EzDefineDialog( DLG_MYDLG,ISUSER , DLG_MYDLG, 0 ) = DLG_ERR) then         
             MessageBox ("Error in defining dialog", SEVERE); 
         return ISERR_GEN_FAILURE;
        endif;          
        bDone = FALSE;     
        //循环
        while (!bDone)
            nId = WaitOnDialog( DLG_MYDLG ); //获得对话框的消息  
            hwndDlg = CmdGetHwndDlg( DLG_MYDLG );
            hwndItem = CtrlGetDlgItem( "", hwndDlg, NEXT );        
            switch (nId)
            case DLG_INIT:
                CtrlSetText( DLG_MYDLG, DataBaseName, svDatabaseName );
                CtrlSetText( DLG_MYDLG, Server, svServer );
                CtrlSetText( DLG_MYDLG, UserName, svUserName );
                CtrlSetText( DLG_MYDLG, Password, svPwd );               
                StrTrim( svDatabaseName )    ;
                StrTrim( svServer )    ;
                StrTrim( svUserName )    ;
                StrTrim( svPwd )   ;   
                if(svPwd=""||svDatabaseName=""||svServer=""||svUserName=""||!CheckConnection(svServer,svDatabaseName,svUserName,svPwd))
                       then                    
                        EnableWindow( hwndItem, FALSE);
                endif;   
            case btnTestConn:
       //调用SqlHelper脚本里的CheckConnection函数
    if(CheckConnection(svServer,svDatabaseName,svUserName,svPwd)) then MessageBox("连接成功",INFORMATION) ; EnableWindow( hwndItem, TRUE); else MessageBox("连接失败",SEVERE) ; EnableWindow( hwndItem, FALSE); endif; case Password: nMessage = CtrlGetSubCommand( DLG_MYDLG ); if( nMessage = EDITBOX_EDITBOXCHANGE ) then CtrlGetText( DLG_MYDLG, Password, svPwd); endif; StrTrim( svPwd ) ; if(svPwd="") then EnableWindow( hwndItem, FALSE); endif; case UserName: nMessage = CtrlGetSubCommand( DLG_MYDLG ); if( nMessage = EDITBOX_CHANGE ) then CtrlGetText( DLG_MYDLG, UserName, svUserName); endif; StrTrim( svUserName ) ; if(svUserName="") then EnableWindow( hwndItem, FALSE); endif; case DataBaseName: nMessage = CtrlGetSubCommand( DLG_MYDLG ); if( nMessage = EDITBOX_CHANGE ) then CtrlGetText( DLG_MYDLG, DataBaseName, svDatabaseName); endif; StrTrim( svDatabaseName ) ; if(svDatabaseName="") then EnableWindow( hwndItem, FALSE); endif; case Server: nMessage = CtrlGetSubCommand( DLG_MYDLG ); if( nMessage = EDITBOX_CHANGE ) then CtrlGetText( DLG_MYDLG, Server, svServer); endif; StrTrim( svServer ) ; if(svServer="") then EnableWindow( hwndItem, FALSE); endif; case BACK: nId=BACK; bDone = TRUE; case NEXT: nId=NEXT; bDone = TRUE; case DLG_ERR: nId = ISERR_GEN_FAILURE; SdError(nId, DLG_MYDLG); bDone = TRUE; case DLG_CLOSE: SdCloseDlg(hDlg, nId, bDone); default: // check standard handling if (SdIsStdButton(nId) && SdDoStdButton(nId)) then bDone = TRUE; endif; endswitch; endwhile; //释放窗体 EndDialog( DLG_MYDLG ); ReleaseDialog( DLG_MYDLG ); SdUnInit( ); MsiSetProperty(ISMSI_HANDLE,"CONN","Data Source="+svServer+";Initial Catalog="+svDatabaseName+";User ID="+svUserName+";Password="+svPwd); return nId; end;


    总结:

    (1)初始化窗口。

    (2)使用While函数写各个控件的事件。

           

         

  • 相关阅读:
    centOS7 安装docker
    go中json的tag使用
    secureCRT操作redis-cli时, 不断追加ip:port
    golang gorm框架的默认时区问题
    java Date 转mysql timestamp 秒数不一致
    golang sqlx查询时, struct字段冲突
    golang入门time与string转换, time加减时间, 两个时间差
    idea设置每次打开手动选择工作空间
    panic: reflect.Value.Interface: cannot return value obtained from unexported field or method
    Render函数(4):开发可进行排序的表格组件
  • 原文地址:https://www.cnblogs.com/forneter/p/3826915.html
Copyright © 2011-2022 走看看