編輯:關於Android編程
1,key -- 實體按鍵
現在手機物理按鍵越來越少
常見的有 KEYCODE_VOLUME_DOWN/UP KEYCODE_POWER KEYCODE_BACK KEYCODE_HOME KEYCODE_MENU
在一個activity 重載父類 的下面這三個方法來處理按鍵事件
public boolean onKeyDown(int keyCode, KeyEvent event): public boolean onKeyUp(int keyCode, KeyEvent event): public boolean onKeyLongPress(int keyCode, KeyEvent event):
很明顯,長按事件一般是放到 onKeyLongPress 函數中來處理的。
那具體是怎麼做的呢,下面請看步驟:
第一步,先在 onKeyDown 函數中判斷 event.getRepeatCount 的次數(實際上長按就是由一系列的onKeyDown事件觸發的).
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { case KeyEvent.KEYCODE_VOLUME_DOWN: case KeyEvent.KEYCODE_VOLUME_UP: if (mCameraAppView.getVisibility() != View.VISIBLE) { return false; } Log.v(TAG,"onKeyDown event.getRepeatCount() "+event.getRepeatCount()); if (event.getRepeatCount() == 0) { event.startTracking(); return true; } return true; } return super.onKeyDown(keyCode, event); } 如果一直按著不放,通過打 log 可以看到 onKeyDown event.getRepeatCount() 0 onKeyDown event.getRepeatCount() 1 onKeyDown event.getRepeatCount() 2 onKeyDown event.getRepeatCount() 3 onKeyDown event.getRepeatCount() 4 onKeyDown event.getRepeatCount() 5 onKeyDown event.getRepeatCount() 6 onKeyDown event.getRepeatCount() 7 onKeyDown event.getRepeatCount() 8 onKeyDown event.getRepeatCount() 9 onKeyDown event.getRepeatCount() 10 onKeyDown event.getRepeatCount() 11 onKeyDown event.getRepeatCount() 12 ……
第二步,重載 onKeyLongPressed 函數,在這個函數中你可以添加你的處理
@Override public boolean onKeyLongPress(int keyCode, KeyEvent event) { Log.v(TAG,"key long pressed keyCode = "+keyCode); switch (keyCode) { case KeyEvent.KEYCODE_VOLUME_UP: case KeyEvent.KEYCODE_VOLUME_DOWN: Log.v(TAG,"KEYCODE_VOLUME_UP/DOWN long pressed"); lockLongPressKey = true; onShutterButtonLongPressed(); return true; default: break; } return super.onKeyLongPress(keyCode, event); }
第三步,如果在onKeyUp 函數中也處理了相同的按鍵的話,那麼需要對 onKeyLongPress 和 onKeyUp 中該按鍵的處理作互斥處理了
public boolean onKeyUp(int keyCode, KeyEvent event) { switch (keyCode) { case KeyEvent.KEYCODE_VOLUME_UP: case KeyEvent.KEYCODE_VOLUME_DOWN: Log.v(TAG, "onKeyUp event.getRepeatCount() "+event.getRepeatCount()); if(lockLongPressKey){ lockLongPressKey = false; return true; } if (event.getRepeatCount() == 0) { Log.v(TAG, "prepare for onShutterButtonClick.."); if (mEnableRecordBtn && mReviewImage.getVisibility() != View.VISIBLE && mBgLearningMessageFrame.getVisibility() == View.GONE) { if (mShutterButton != null && mShutterButton.isEnabled()) { onShutterButtonFocus(false); collapseCameraControls();//fulin@20121101@fix PD1218 B121027-224 onShutterButtonClick(); } } } if (mCameraAppView.getVisibility() != View.VISIBLE) { return false; } return true; } return super.onKeyUp(keyCode, event); }
互斥處理的原因是,長按事件處理完後,松開按鍵後就會執行 onKeyUp 函數。而這兩處針對相同的按鍵想要實現的功能又不一樣
固在此添加一個 private boolean lockLongPressKey = false; 變量,在 onKeyLongPress 函數中處理過以後,在 onKeyUp中便不再處理。
2, button
自定義的 button 長按事件則是通過實現 OnLongClickListener 接口來做到的。
import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnLongClickListener; import android.widget.Button; import android.widget.Toast; public class MyActivity extends Activity implements OnLongClickListener{ Button button;//聲明按鈕的引用 public void onCreate(Bundle savedInstanceState) {//重寫的onCreate方法 super.onCreate(savedInstanceState); setContentView(R.layout.main); button = (Button) this.findViewById(R.id.button);//得到按鈕的引用 button.setTextSize(20); button.setOnLongClickListener(this);//注冊監聽 } public boolean onLongClick(View v) {//實現接口中的方法 if(v == button){//當按下的是按鈕時 Toast.makeText( this, "長時間按下了按鈕", Toast.LENGTH_SHORT ).show();//顯示提示 } return false; } }
以上,就是小編對Android 監聽按鍵的長按事件詳解,歡迎補充,謝謝支持!
1.ListView和Adapter1)ListView就是一個能數據集合以動態滾動的方式展示到用戶界面上的View,即:以列表的形式展示具體內容,並且能夠根據數據的長度
仿水波紋流球進度條控制器,Android實現高端大氣的主流特效,供大家參考,具體內容如下效果圖:CircleView這裡主要是實現中心圓以及水波特效package com
1.主要代碼: 聲明: private View shareView; private PopupWindow pop; 在onCreate方法裡: // 引入
之前一篇文章,介紹了如何定義從屏幕底部彈出PopupWindow即《Android Animation實戰之屏幕底部彈出PopupWindow》,寫完之後,突然想起之前寫