VC選項按鈕控制項(Radio Button)用法

來源:互聯網
上載者:User

標籤:class   code   http   com   get   使用   

先為對話方塊加上2個radio button,分別是Radio1和Radio2。

問題1:如何讓Radio1或者Radio2預設選上?如何知道哪個被選上了?

關鍵是選上,“預設”只要放在OnInitDialog()即可。三種方法可以讓它選上,

第一種:
((CButton *)GetDlgItem(IDC_RADIO1))->SetCheck(TRUE);//選上
((CButton *)GetDlgItem(IDC_RADIO1))->SetCheck(FALSE);//不選上
((CButton *)GetDlgItem(IDC_RADIO1))->GetCheck();返回1表示選上,0表示沒選上
有時候vc提示沒有GetCheck()函數,可以使用GetCheckedRadioButton;

CWnd::GetCheckedRadioButton

函數功能:在給定的一組單選框ID中獲得當前被選中的選項按鈕的ID

函數原型:int GetCheckedRadioButton( int nIDFirstButton, int nIDLastButton );

傳回值: 當有被選中的單選框時返回被選中的單選框的ID ,如果所給的組中都沒被選中則返回0

注意:在MFC中,這些按鈕的控制項ID要連續遞增!

參數:

nIDFirstButton 單選框組中第一個整形值的ID

nIDLastButton 單選框組中最後一個整形值ID

switch(GetCheckedRadioButton(IDC_RADIO1,IDC_RADIO4))

                             {                                     case  IDC_RADIO1:                                              MessageBox(_T( "100" ));                                              break ;                                     case  IDC_RADIO2:                                              MessageBox(_T( "90" ));                                              break ;                                     case  IDC_RADIO3:                                              MessageBox(_T( "80" ));                                              break ;                                     case  IDC_RADIO4:                                              MessageBox(_T( "70" ));                                              break ;                              }


第二種:
關聯一個congtrol型變數(子類化),好ctrl+W(即開啟classwizard),點開 Member Variables,咦?怎麼沒有IDC_RADIO1這個ID?原來是沒有分組。因為radio button通常都是成組使用的,在一組裡面是互斥的。取消,回到對話方塊資源面板,右鍵Radio1查看屬性把Group選上,那麼,Radio1和 Radio2就是一組了(怎麼知道他們是一組的?後面說)。此時,就可以為Radio1增加一congtrol型變數m_ctrlRadio1了。如下:
m_ctrlRadio1.SetCheck(TRUE);
同樣可以使用GetCheck()擷取狀態。

第三種:
關聯一個int型變數(同樣需要先分組)m_nRadio1,開啟對話方塊建構函式,你會發現有:
m_nRadio1 = -1;m_nRadio1別賦值-1表示哪個都沒有選上。如果你把-1改成0,就會發現Radio1預設被選上了,依此類推,m_nRadio1的值為1 就是第二個被選上了(這裡同樣有問題,哪個是第一個?哪個是第二個?)。擷取狀態很簡單,UpdateData(TRUE)後判斷m_nRadio1的值即可。

問題2:如何使用多組?

多組和一組是一樣的使用,只要搞清楚哪個是哪一組的就行了。再為對話方塊添加Radio3和Radio4。很簡單,先為這些Radio Button排個順序(這個必須要做,比如你的一組控制項有Radio1,Radio2,Radio3,就把它們的TAB順序分別設為1,2,3,並將Radio1的Group屬性設為True,這樣,當選中Radio1的時候和它關聯的變數就是0,當選中Radio2的時候和它關聯的變數就是1,依此類推),就是排列他們的TAB ORDER。在對話方塊資源面板上Ctrl+D,然後按你自己的理想順序用滑鼠逐個點擊就可以了。不妨假設Radio1、Radio2、Radio3、 Radio4分別是1、2、3、4。Radio1和Radio3都選上Group屬性,那麼,1、2是一組,3、4是另外一組,因為分組的原則是在選上 Group屬性的這一個開始直到碰到下一個選上Group屬性的。你不妨再Ctrl+D,令Radio1、Radio2、Radio3、Radio4分別是1、3、2、4,那麼Radio1和Radio3是一組,如果m_nRadio1=1,此時是Radio3被選上而不是Radio2被選上。分好了組就分別使用它們吧。
嗯,也許你還要為它們添加按一下滑鼠事件,非常簡單。

一、對選項按鈕進行分組:
每組的第一個選項按鈕設定屬性:Group,Tabstop,Auto;其餘按鈕設定屬性Tabstop,Auto。如:
Radio1、Radio2、Radio3為一組,Radio4、Radio5為一組
設定Radio1屬性:Group,Tabstop,Auto
設定Radio2屬性:Tabstop,Auto
設定Radio3屬性:Tabstop,Auto
設定Radio4屬性:Group,Tabstop,Auto
設定Radio5屬性:Tabstop,Auto

二、用ClassWizard為單選控制項定義變數,每組只能定義一個。如:m_Radio1、m_Radio4。

三、用ClassWizard產生各選項按鈕的單擊訊息函數,並加入內容:
void CWEditView::OnRadio1()
{
    m_Radio1 = 0;    //第一個選項按鈕被選中
}
void CWEditView::OnRadio2()
{
    m_Radio1 = 1;    //第二個選項按鈕被選中
}
void CWEditView::OnRadio3()
{
    m_Radio1 = 2;    //第三個選項按鈕被選中
}
void CWEditView::OnRadio4()
{
    m_Radio4 = 0;    //第四個選項按鈕被選中
}
void CWEditView::OnRadio5()
{
    m_Radio4 = 1;    //第五個選項按鈕被選中
}

四、設定預設按鈕:
在定義控制項變數時,ClassWizard在建構函式中會把變數初值設為-1,只需把它改為其它值即可。
如:
//{{AFX_DATA_INIT(CUnitBlockTypeFlankPublicAdd)
m_Radio1 = 0;    //初始時第一個選項按鈕被選中
m_Radio4 = 0;    //初始時第四個選項按鈕被選中
//}}AFX_DATA_INIT

 

 

轉載:http://club.topsage.com/thread-670221-1-1.html,

有修改

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.