• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            渴望飛翔
            Fly in the C++ Sky...
            posts - 9,  comments - 6,  trackbacks - 0

            在做一個MFC軟件的時候有一個這樣的需求,就是要有類似與AutoCad的命令輸入框,如下圖所示:

             

            本著不重寫已有功能的原則,在MFC中發掘了一圈,沒發現有可用的現成控件,上網搜了一下,發現有人做過,但竟然還收費出售,so faint,只能自己動手做一個。

            其實思路還是蠻簡單的,就是放個Edit控件處理它的鍵盤輸入事件,防止刪除之前的記錄和提示信息,還要處理結束命令,比如回車、空格之類的。主要有以下幾個步驟:

            1. 將輸入框內的字符串分段,比如分成三段log, tip和command,前兩段都不能被修改,command的內容為可修改的。在結束了command輸入后,要同步各字符串,示例代碼如下:

            void CMainFrame::InitCommand(CString tip)
            {
             // 記錄老字符串,類似于UpdateData(true)

             this->GetText();

             // 設置新的log
             if(this->m_log != "")
              this->m_log += "\r\n";
             this->m_log += tip;

             // 更新字符串,類似與UpdataData(false)
             this->SetText();

             // 將光標置于字符串的尾部(否則光標會在一開始的位置)

             ((CEdit *)m_commandDialogBar.GetDlgItem(IDC_COMMAND))->SetSel(this->m_log.GetLength(),
              this->m_log.GetLength());
            }

            2. 重載PreTranslateMessage事件,處理鍵盤信息,示例代碼如下:

             BOOL CMainFrame::PreTranslateMessage(MSG* pMsg)
            {
             if(pMsg->message == WM_KEYDOWN) // 處理鍵盤按下事件
             {
              // 判斷是否是在腳本輸入框上輸入的

              if(GetFocus() == m_commandDialogBar.GetDlgItem(IDC_COMMAND))
              {
               // 如果選擇的是非正在輸入的文字,拋棄這個事件

               DWORD selectedRegion = ((CEdit *)m_commandDialogBar.GetDlgItem(IDC_COMMAND))->GetSel();
               int selectedStart = LOWORD(selectedRegion);
               int selectedEnd   = HIWORD(selectedRegion);

               if(selectedStart != selectedEnd && selectedStart < m_log.GetLength())
                return true;

               if(pMsg->wParam == 8 && selectedStart <= m_log.GetLength()) // 阻止刪除之前的文字
                return true;

               if(pMsg->wParam == 13 || pMsg->wParam == 32) // 當輸入空格或回車是發送消息
                this->SendCommand();
              }
             }

             return CMDIFrameWnd::PreTranslateMessage(pMsg);
            }

            其中SendCommand的內容可自定義,處理完成后不要忘記執行1的操作,同步一下字符串就OK。實現效果如下:

            當然,這是一個最簡單的實現,還有很多問題沒有處理,比如自定義菜單,屏蔽系統菜單等;還有很多工作可以做,比如封裝成一個自定義控件,做更好的顯示效果等等。但基本的思路還是一樣的,恩,如果誰有更好的實現方案,也歡迎留言,謝謝先:)



            duguguiyu 2007-07-21 21:43 發表評論

            文章來源:http://www.cnblogs.com/duguguiyu/archive/2007/07/21/826901.html
            posted on 2007-07-21 21:43 duguguiyu 閱讀(716) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            Welcome to my c++ home...

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(1)

            隨筆分類(9)

            隨筆檔案(9)

            搜索

            •  

            積分與排名

            • 積分 - 10712
            • 排名 - 1158

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品免费一区二区三区| 99久久精品无码一区二区毛片| 久久不见久久见免费影院www日本| 97久久天天综合色天天综合色hd| 99久久成人国产精品免费| 99久久国产免费福利| 成人综合久久精品色婷婷| 久久夜色精品国产噜噜麻豆| 99久久精品免费观看国产| 99久久国产精品免费一区二区| 精品久久久久久久久中文字幕| 色天使久久综合网天天| 精品久久久久久久久午夜福利| 久久人人爽人爽人人爽av| 久久综合88熟人妻| 亚洲日韩欧美一区久久久久我| .精品久久久麻豆国产精品| 日本精品久久久久久久久免费| 久久无码人妻一区二区三区| 久久午夜福利电影| 亚洲国产精品久久久久婷婷软件| av色综合久久天堂av色综合在 | 狠狠色丁香婷婷久久综合不卡| 欧美午夜A∨大片久久 | 久久久精品人妻无码专区不卡| 色综合久久久久无码专区| 性高朝久久久久久久久久| 久久久精品人妻一区二区三区蜜桃| 久久精品国产99久久香蕉| 国产福利电影一区二区三区久久久久成人精品综合 | 人人狠狠综合久久亚洲88| 国产69精品久久久久9999APGF | 一97日本道伊人久久综合影院| 久久99精品国产麻豆婷婷| 99精品伊人久久久大香线蕉| 午夜福利91久久福利| 国产美女久久久| 久久婷婷五月综合97色直播| 热久久国产欧美一区二区精品| 人妻无码αv中文字幕久久琪琪布| 久久精品国产亚洲Aⅴ香蕉 |