[Android]Java中點擊事件的四種寫法

来源:http://www.cnblogs.com/pinnsvin/archive/2017/05/17/6869067.html
-Advertisement-
Play Games

點擊事件的必備條件:實現 介面,重寫 方法 以撥號簡單案例為例,如下圖效果: 邏輯流程: 1. 獲取點擊對象,獲取數據 2. 給對象設置監聽類 3. 實現 介面,重寫 方法 邏輯: 1. 獲取輸入內容:使用 對象的 方法,該方法返回值為 ,需要用 轉換成 類型 2. 判斷輸入是否為空, 方法判斷字元 ...


點擊事件的必備條件:實現OnClickListener介面,重寫onclick(View v)方法

以撥號簡單案例為例,如下圖效果:
演示圖片

邏輯流程:

  1. 獲取點擊對象,獲取數據
  2. 給對象設置監聽類
  3. 實現OnClickListener介面,重寫onClick(View v)方法

onClick(View v)邏輯:

  1. 獲取輸入內容:使用EditText對象的getText()方法,該方法返回值為Editable,需要用toString()轉換成String類型

  2. 判斷輸入是否為空,TextUtils.isEmpty(str)方法判斷字元串str是否為空

  3. 為空則提示號碼不能為空,使用Toast.makeText(MainActivity.this, "號碼不能為空", Toast.LENGTH_SHORT).show();,
    Toast makeText (Context context, CharSequence text, int duration)返回值為Toast,參數列表(Context對象,提示內容,顯示時長)

  1. 如果不為空,new一個Intent對象,使用Intent對象的setAction(String action)方法設置動作,使用Intent對象的setData(Uri uriData)方法設置數據。startActivity(Intent intent)方法啟動Activity。

註:應該在程式清單文件AndroidManifest.xml中添加<uses-permission android:name="android.permission.CALL_PHONE"/>,撥打電話時,美國緊急電話不會直接撥打

三種方法:第四種不推薦,前三種酌情使用

1. 內部實現類

佈局文件:activity_main.xml

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="${relativePackage}.${activityClass}" >


    <EditText
        android:id="@+id/editText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:hint="在此輸入電話號碼">

    </EditText>

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/editText1"
        android:layout_marginTop="14dp"
        android:text="撥打此號碼" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/button1"
        android:text="Button2" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/button2"
        android:text="Button3" />


</RelativeLayout>

MainActivity.java

    package com.example.onclick1;

    import android.app.Activity;
    import android.content.Intent;
    import android.net.Uri;
    import android.os.Bundle;
    import android.os.storage.OnObbStateChangeListener;
    import android.text.TextUtils;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;

    public class MainActivity extends Activity {

        private EditText editText;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            editText = (EditText) findViewById(R.id.editText1);
            Button button1 = (Button) findViewById(R.id.button1);
            Button button2 = (Button) findViewById(R.id.button2);
            Button button3 = (Button) findViewById(R.id.button3);

            //設置監聽類
            button1.setOnClickListener(new MyOnClickListener());
            button2.setOnClickListener(new MyOnClickListener());
            button3.setOnClickListener(new MyOnClickListener());
        }
        private class MyOnClickListener implements OnClickListener{

            @Override
            public void onClick(View v) {
                int i = v.getId();
                switch (i) {
                case R.id.button1:
                    String number = editText.getText().toString();
                    if (TextUtils.isEmpty(number)) {
                        Toast.makeText(MainActivity.this, "號碼不能為空", Toast.LENGTH_SHORT).show();
                    }else {
                        Intent intent = new Intent();
                        intent.setAction(intent.ACTION_CALL);
                        Uri data = Uri.parse("tel:"+number);
                        intent.setData(data);
                        startActivity(intent);
                    }

                    break;
                case R.id.button2:
                    Toast.makeText(MainActivity.this, "你點擊了Button2", Toast.LENGTH_SHORT).show();
                    break;
                case R.id.button3:
                    Toast.makeText(MainActivity.this, "你點擊了Button3", Toast.LENGTH_SHORT).show();
                    break;
                }
            }

        }
    }

2. 內部匿名類

MainActivity.java

    package com.example.onclick1;

    import android.app.Activity;
    import android.content.Intent;
    import android.net.Uri;
    import android.os.Bundle;
    import android.os.storage.OnObbStateChangeListener;
    import android.text.TextUtils;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;

    public class MainActivity extends Activity {

        private EditText editText;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            editText = (EditText) findViewById(R.id.editText1);
            Button button1 = (Button) findViewById(R.id.button1);
            Button button2 = (Button) findViewById(R.id.button2);
            Button button3 = (Button) findViewById(R.id.button3);

            //設置監聽類
            button1.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {
                    String number = editText.getText().toString();
                    if(TextUtils.isEmpty(number)){
                        Toast.makeText(MainActivity.this, "[內部匿名類]號碼不能為空", Toast.LENGTH_SHORT).show();
                    }else{
                        Intent intent = new Intent();
                        intent.setAction(intent.ACTION_CALL);
                        intent.setData(Uri.parse("tel:"+number));
                        startActivity(intent);
                    }
                }
            });
            button2.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {
                    Toast.makeText(MainActivity.this, "[內部匿名類]你點擊了Button2", Toast.LENGTH_SHORT).show();
                }
            });
            button3.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {
                    Toast.makeText(MainActivity.this, "[內部匿名類]你又點擊了button3", Toast.LENGTH_SHORT).show();

                }
            });
        }
    }

3. Activity實現OnClickLitener

MainActivity.java

    package com.example.onclick1;

    import android.app.Activity;
    import android.content.Intent;
    import android.net.Uri;
    import android.os.Bundle;
    import android.os.storage.OnObbStateChangeListener;
    import android.text.TextUtils;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;

    public class MainActivity extends Activity implements OnClickListener{

        private EditText editText;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            editText = (EditText) findViewById(R.id.editText1);
            Button button1 = (Button) findViewById(R.id.button1);
            Button button2 = (Button) findViewById(R.id.button2);
            Button button3 = (Button) findViewById(R.id.button3);

            //設置監聽類
            button1.setOnClickListener(this);
            button2.setOnClickListener(this);
            button3.setOnClickListener(this);
        }
        @Override
        public void onClick(View v) {
            int id = v.getId();
            switch (id) {
            case R.id.button1:
                String number = editText.getText().toString();
                if (TextUtils.isEmpty(number)) {
                    Toast.makeText(this, "[Activity實現類]號碼不能為空", Toast.LENGTH_SHORT).show();
                }else {
                    Intent intent = new Intent();
                    intent.setAction(intent.ACTION_CALL);
                    intent.setData(Uri.parse("tel:"+number));
                    startActivity(intent);
                }
                break;
            case R.id.button2:
                Toast.makeText(this, "[Activity實現類]你點擊了Button2", Toast.LENGTH_SHORT).show();
                break;
            case R.id.button3:
                Toast.makeText(this, "[Activity實現類]你點擊了Button3", Toast.LENGTH_SHORT).show();
                break;
            }
        }
    }

4. 結合layout文件聲明方法

activity_main.xml

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context="${relativePackage}.${activityClass}" >


        <EditText
            android:id="@+id/editText1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:focusable="true"
            android:focusableInTouchMode="true"
            android:hint="在此輸入電話號碼">

        </EditText>

        <Button
            android:id="@+id/button1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/editText1"
            android:layout_marginTop="14dp"
            android:onClick="button"
            android:text="撥打此號碼" />

        <Button
            android:id="@+id/button2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_below="@+id/button1"
            android:onClick="button"
            android:text="Button2" />

        <Button
            android:id="@+id/button3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_below="@+id/button2"
            android:onClick="button"
            android:text="Button3" />


    </RelativeLayout>

MainActivity.java

    package com.example.onclick1;

    import android.app.Activity;
    import android.content.Intent;
    import android.net.Uri;
    import android.os.Bundle;
    import android.os.storage.OnObbStateChangeListener;
    import android.text.TextUtils;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.widget.EditText;
    import android.widget.Toast;

    public class MainActivity extends Activity{

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
        public void button(View v) {
        EditText editText = (EditText) findViewById(R.id.editText1);
            switch (v.getId()) {
            case R.id.button1:
                String number = editText.getText().toString();
                if (TextUtils.isEmpty(number)) {
                    Toast.makeText(this, "[佈局文件中Button的android:onClick屬性]號碼不能為空", Toast.LENGTH_SHORT).show();
                }else {
                    Intent intent = new Intent();
                    intent.setAction(intent.ACTION_CALL);
                    intent.setData(Uri.parse("tel:"+number));
                    startActivity(intent);
                }
                break;
            case R.id.button2:
                Toast.makeText(this, "[佈局文件中Button的android:onClick屬性]你點擊了Button2", Toast.LENGTH_SHORT).show();
                break;
            case R.id.button3:
                Toast.makeText(this, "[佈局文件中Button的android:onClick屬性]你點擊了Button3", Toast.LENGTH_SHORT).show();
                break;
            }
        }
    }

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、我們先解釋一下他的含義: 1、Token的引入:Token是在客戶端頻繁向服務端請求數據,服務端頻繁的去資料庫查詢用戶名和密碼併進行對比,判斷用戶名和密碼正確與否,並作出相應提示,在這樣的背景下,Token便應運而生。 2、Token的定義:Token是服務端生成的一串字元串,以作客戶端進行請求 ...
  • 首先,需要一個電話號碼,目前很多賬戶都是將賬戶名設置成手機號,然後點擊按鈕獲取手機驗證碼。 其次,你需要後臺給你手機簡訊的驗證介面,各個公司用的不一樣,這個身為前端,不需要你來考慮,你只要讓你後臺給你寫好介面,你直接調用就好了。 activity_login.xml LoginActivity.ja ...
  • 1.阿裡巴巴的熱修複框架(AndFix) 1 . 添加依賴2. 儘可能早的載入補丁3. 修複bug,生成沒有bug的apk文件4. 對比新舊apk生成.apatch補丁文件5. 載入新補丁,修複bug http://blog.csdn.net/qq_17250009/article/details/ ...
  • activity_collect.xml ...
  • activity_detail.xml 1.點擊收藏 2.社會化分享 ...
  • 1.獲得緩存大小和清除緩存 應用內數據的所有路徑: /data/data/com.xxx.xxx/cache - 應用內緩存(註:對應方法getCacheDir()) /data/data/com.xxx.xxx/databases - 應用內資料庫 /data/data/com.xxx.xxx/s ...
  • 文章參考自:http://www.runoob.com/w3cnote/android-tutorial-button-imagebutton.html Button是TextView的子類,所以TextView上很多屬性也可以應用到Button 上!我們實際開發中對於Button的,無非是對按鈕的 ...
  • 比較簡單的一個控制項,就是加些邏輯處理而已,以前貌似是直接監聽的,封裝起來方便點 public class AccountTxtView extends android.support.v7.widget.AppCompatEditText { private final char CUT = '-' ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...