• <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>

            life02

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              197 隨筆 :: 3 文章 :: 37 評論 :: 0 Trackbacks
            http://android.blog.51cto.com/268543/323982


            Activity跳轉與傳值,主要是通過Intent類來連接多個Activity,以及傳遞數據。
             
            Intent是Android一個很重要的類。Intent直譯是“意圖”,什么是意圖呢?比如你想從這個Activity跳轉到另外一個Activity,這就是一個意圖。Intent類在Android系統中的作用很大,在此不詳細說了,后面有文章介紹!
             

            Activity跳轉,無返回結果

               這是最簡單的Activity跳轉方式。從一個Activity啟動另一個Activity,直接startActivity(new Intent(當前Activity.this, 下一Activity.class))。
            1. ((Button) findViewById(R.id.Notepadv1)).setOnClickListener( new OnClickListener() {  
            2.     public void onClick(View v) {  
            3.         startActivity(new Intent (MyAndroidAppActivity.this, Notepadv1.class) );  
            4.     }  
            5. }); 
             

            Activity跳轉,返回數據/結果

               需要返回數據或結果的,則使用startActivityForResult (Intent intent, int requestCode)
            ,requestCode的值是自定義的,用于識別跳轉的目標Activity。
               跳轉的目標Activity所要做的就是返回數據/結果,setResult(int resultCode)只返回結果不帶數據,或者setResult(int resultCode, Intent data)兩者都返回!
               而接收返回的數據/結果的處理函數是onActivityResult(int requestCode, int resultCode, Intent data),這里的requestCode就是startActivityForResult的requestCode,resultCode就是setResult里面的resultCode,返回的數據在data里面。
             
            MyAndroidAppActivity:
            1. static final int SEND_SMS_REQUEST = 0; 
            2. static final int CALL_REQUEST = 1; 
            3.  
            4. ((Button) findViewById(R.id.sms)).setOnClickListener( new OnClickListener() { 
            5.     public void onClick(View v) { 
            6.         Intent intent = new Intent(MyAndroidAppActivity.this, SendSMSActivity.class); 
            7.         startActivityForResult(intent, SEND_SMS_REQUEST); 
            8.     } 
            9. }); 
            10.  
            11. @Override 
            12. protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
            13.     if (requestCode == SEND_SMS_REQUEST) { 
            14.         if (resultCode == RESULT_OK) { 
            15.             Toast.makeText(this, "Send SMS RESULT_OK", Toast.LENGTH_SHORT).show(); 
            16.         }else if (resultCode == RESULT_CANCELED) { 
            17.             Bundle bundle = data.getExtras(); 
            18.             String phoneno = bundle.getString("phoneNO");  
            19.             Toast.makeText(this, "Send SMS RESULT_CANCELED "+phoneno, Toast.LENGTH_SHORT).show(); 
            20.         } 
            21.     }else if (requestCode == CALL_REQUEST) { 
            22.         if (resultCode == RESULT_CANCELED) { 
            23.             Toast.makeText(this, "Call RESULT_CANCELED", Toast.LENGTH_SHORT).show(); 
            24.         } 
            25.     } 
             
            SendSMSActivity:
            1. ((Button) findViewById(R.id.send)).setOnClickListener( new Button.OnClickListener() { 
            2.     public void onClick(View v) { 
            3.         SendSMSActivity.this.setResult(RESULT_OK); 
            4.         SendSMSActivity.this.finish(); 
            5.     } 
            6. }): 
             
            ** 注意,在setResult后,要調用finish()銷毀當前的Activity,否則無法返回到原來的Activity,就無法執行原來Activity的onActivityResult函數,看到當前的Activity沒反應。
             
                RESULT_OK和RESULT_CANCELED是系統空間里面的常量,不需要自定義,直接使用就行。
             
               另外在運行過程中,發現按Back鍵后,是可以返回RESULT_CANCELED的,看了SDK doc后,原來真的是那樣,而且不帶有數據的。這意味著,如果你設想在返回RESULT_CANCELED時并返回數據,那么需要截獲Back鍵的事件處理,把原來返回RESULT_CANCELED的核心邏輯copy到事件處理里面。這里給個例子:
             
            1. ((Button) findViewById(R.id.cancel)).setOnClickListener( new Button.OnClickListener() { 
            2.     public void onClick(View v) { 
            3.         // 實例化 Bundle,設置需要傳遞的參數 
            4.         Bundle bundle = new Bundle(); 
            5.         bundle.putString("phoneNO", "020-123"); 
            6.  
            7.         SendSMSActivity.this.setResult(RESULT_CANCELED, SendSMSActivity.this.getIntent().putExtras(bundle)); 
            8.         SendSMSActivity.this.finish(); 
            9.     } 
            10. }); 
            11.  
            12. @Override 
            13. public boolean onKeyDown(int keyCode, KeyEvent event) { 
            14.     // 是否觸發按鍵為back鍵    
            15.     if (keyCode == KeyEvent.KEYCODE_BACK) { 
            16.          
            17.         // 實例化 Bundle,設置需要傳遞的參數 
            18.         Bundle bundle = new Bundle(); 
            19.         bundle.putString("phoneNO", "020-123"); 
            20.          
            21.         setResult(RESULT_CANCELED, this.getIntent().putExtras(bundle)); 
            22.         this.finish(); 
            23.         return true; 
            24.     }else { 
            25.         return super.onKeyDown(keyCode, event); 
            26.     } 
                這里要注意的是,在處理Back鍵事件后return true則表示本事件不再傳遞給其他函數處理,可理解為由當前函數全權負責處理,所以在return前finish當前Activity,保持原來的行為 表現,當然我們可以設置為隱藏當前Activity等其他行為。
             

            Activity傳送數據

                在上面的代碼中,我們可以看到使用Bundle來存儲數據,并將其putExtras到Intent里面。Bundle使用“名字-值”來存儲數據。那 么,從原來的Activity A傳送數據到新的Activity B, Activity B如何獲取傳送過來的Intent參數時呢?最近寫了這樣的一個例子:
             
            In Activity A:
            1. // 在某個按鈕響應事件里 
            2. Intent intent = new Intent(this, TextInputActivity.class); 
            3. intent.putExtra("Text", mText); 
            4. intent.putExtra("TextColor", mTextColor); 
            5. intent.putExtra("TextSize", mTextSize); 
            6. intent.putExtra("TextBold", mTextBold); 
            7.  
            8. startActivityForResult(intent, REQUEST_TEXT); 
            In Activity B:
            1. // in onCreate(Bundle savedInstanceState) 
            2. Bundle extras = getIntent().getExtras(); 
            3. mText = extras.getString("Text"); 
            4. mTextColor = extras.getInt("TextColor"); 
            5. mTextSize = extras.getFloat("TextSize"); 
            6. mTextBold = extras.getBoolean("TextBold"); 
             
             

            本文出自 “學習Android” 博客,請務必保留此出處http://android.blog.51cto.com/268543/323982


            posted on 2012-02-05 22:09 life02 閱讀(289) 評論(0)  編輯 收藏 引用 所屬分類: android組件學習
            无码8090精品久久一区| 伊人久久免费视频| 性做久久久久久久久久久| 亚洲午夜无码久久久久小说| 2020久久精品亚洲热综合一本| 欧美亚洲国产精品久久| 久久精品国产亚洲77777| 91精品国产色综久久| 亚洲中文字幕无码久久2020| 日韩精品久久久久久| 免费精品久久天干天干| 国产99精品久久| 伊人久久无码中文字幕| 国产精品成人99久久久久| 久久精品国产亚洲av日韩| 日产久久强奸免费的看| 日本精品久久久久中文字幕8| 亚洲天堂久久久| 色欲综合久久躁天天躁| 国产高清美女一级a毛片久久w| 久久久一本精品99久久精品66| 久久久久国产一区二区| 99久久夜色精品国产网站| 漂亮人妻被黑人久久精品| 99久久这里只精品国产免费| 久久亚洲av无码精品浪潮| 亚洲乱亚洲乱淫久久| 久久91精品国产91久久户| 久久精品www人人爽人人| 亚洲色婷婷综合久久| 精品久久久久成人码免费动漫| 亚洲国产高清精品线久久| 久久亚洲AV无码西西人体| 亚洲精品NV久久久久久久久久| 国产精品成人精品久久久| 91久久精品国产91性色也| 久久国产精品-久久精品| 国产精品一久久香蕉国产线看| 久久不见久久见免费视频7| 久久66热人妻偷产精品9| 99麻豆久久久国产精品免费|