編輯:關於Android編程
Android事件構成:
在Android中,事件主要包括點按、長按、拖拽、滑動等,點按又包括單擊和雙擊,另外還包括單指操作和多指操作。所有這些都構成了Android中的事件響應。總的來說,所有的事件都由如下三個部分作為基礎:
跟touch事件相關的3個方法:
public boolean dispatchTouchEvent(MotionEvent ev); //用來分派event public boolean onInterceptTouchEvent(MotionEvent ev); //用來攔截event public boolean onTouchEvent(MotionEvent ev); //用來處理eventAndroid事件處理的機制:
onInterceptTouchEvent():
決定是否允許Touch事件繼續向下(子控件)傳遞,一但返回True(代表事件在當前的viewGroup中會被處理),則向下傳遞之路被截斷(所有子控件將沒有機會參與Touch事件),同時把事件傳遞給當前的控件的onTouchEvent()處理;返回false,則把事件交給子控件的onInterceptTouchEvent()。<喎?/kf/ware/vc/" target="_blank" class="keylink">vcD4NCjxwPjxlbT5kaXNwYXRjaFRvdWNoRXZlbnQoKaO6PC9lbT48YnIgLz4NCre1u9jWtb72tqjKx7fxz/LPwrfWt6LV4rj2ysK8/qOst7W72HRydWWjrNTyt9a3osrCvP64+NfTv9i8/qOst/HU8qOssru31reidG91Y2jKwrz+uPjX07/YvP6hozwvcD4NCjxwPjxlbT5vblRvdWNoRXZlbnQoKaO6PC9lbT48YnIgLz4NCre1u9jWtb72tqi1scewv9i8/srHt/HP+7fRb25Ub3VjaMHL1eK49srCvP4st7W72GZhbHNlo6zU8s/yyc+0q7XduPi4uL/YvP6jrLe1u9h0cnVlo6zU8s/7t9G0y8rCvP6hozxiciAvPg0KPGltZyBhbHQ9"這裡寫圖片描述" src="/uploadfile/Collfiles/20150928/2015092808543163.png" title="\" />
模擬下拉刷新:
/**
* 事件的傳遞:新建一個類繼承於FrameLayout,實現其構造方法
* 必須實現三個處理事件的方法:onInterceptTouchEvent()、
* dispatchTouchEvent()、onTouchEvent()
*/
public class MyFreshLayout extends FrameLayout {
private ListView mListView;
private float oldY;
private float y;
public MyFreshLayout(Context context) {
super(context);
}
public MyFreshLayout(Context context, AttributeSet attrs) {
super(context, attrs);
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View header = inflater.inflate(R.layout.header,null);
addView(header);
mListView = (ListView) inflater.inflate(R.layout.content,null);
addView(mListView);
ArrayAdapter adapter = new ArrayAdapter(context,android.R.layout.simple_list_item_1
,new String[]{A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P});
mListView.setAdapter(adapter);
}
public MyFreshLayout(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
if(mListView.getFirstVisiblePosition()==0){
View firstView = mListView.getChildAt(0);
if(firstView.getY()>=0){
return true;
}
}
return super.onInterceptHoverEvent(event);
}
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
/*if(mListView.getFirstVisiblePosition()==0){
View firstView = mListView.getChildAt(mListView.getFirstVisiblePosition());
if(firstView.getY()>=0){
return true;
}
}*/
return super.dispatchTouchEvent(ev);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()){
case MotionEvent.ACTION_DOWN:
/**
* 得到觸碰焦點的y坐標
*/
oldY = event.getY();
break;
case MotionEvent.ACTION_MOVE:
y = event.getY();
float distance = y - oldY;
//讓mListView移動距離等於手指滑動距離
mListView.setTranslationY(mListView.getTranslationY()+distance);
oldY = y;
break;
case MotionEvent.ACTION_UP:
//手指釋放後mListView恢復初始狀態
ObjectAnimator.ofFloat(mListView,translationY,mListView.getTranslationY(),0)
.setDuration(300).start();
break;
}
return true;
}
}
header,作為首部的布局,首部初始時被覆蓋:
<framelayout android:layout_height="match_parent" android:layout_width="match_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android">
</framelayout>
content,主要內容:
布局:
主活動:
public class MainActivity extends Activity {
private MyFreshLayout myFreshLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myFreshLayout = (MyFreshLayout) findViewById(R.id.my_surfaceView);
}
}
結果演示:
現在我們的手機一般都內置有方向感應器,手機屏幕會根據所處位置自動進行橫豎屏切換(前提是未鎖定屏幕方向)。但有時我們的應用程序僅限在橫屏或者豎屏狀態下才可以運行,此時我們需
在上篇文章Android 源碼系列之<十>從源碼的角度深入理解AccessibilityService,打造自己的APP小外掛(上)中我們講解了通過Acces
這是作為上一篇Android 數據存儲 如何搞定SQLite Database的實例練習,之所以單獨列出來是因為除了數據庫方面的知識,還涉及其它方面的知識,
首先需要搭建一個Tomcat服務器,然後測試服務器上的圖片使用PC上的浏覽器是否可以正常下載下來可以看到服務器上的圖片數據是可以正常訪問的。圖片的地址:http://lo