读代码我们不难发现,所有显示联系的代码就在DefaultContactBrowseListFragment类里面,我们仔细看其代码会发现里面会有这样的方法
protected void onItemClick(int position, long id) {
LogUtils.i(TAG, "[onItemClick][launch]start");
viewContact(getAdapter().getContactUri(position));
LogUtils.i(TAG, "[onItemClick][launch]end");
}
LogUtils.i(TAG, "[onItemClick][launch]start");
viewContact(getAdapter().getContactUri(position));
LogUtils.i(TAG, "[onItemClick][launch]end");
}
此方法是用来做单击事件的,但是并未给我们提供长按的监听器,接下来再看DefaultContactBrowseListFragment 并未去实现其OnItemClickListener 接口,所以我们不难判定onItemClick方法 是重写的夫类的方法,看DefaultContactBrowseListFragment extends ContactBrowseListFragment 但是我们发现其夫类并未有实现单击事件的接口,那就看其夫类的夫类,最终我们会找到ContactEntryListFragment
这个类实现了OnItemClickListener 接口,让我们注意的是此类是抽象类,然并乱其有 protected abstract void onItemClick(int position, long id);
提供外界去访问,
这样看来就加但多了 ,我们可以根据单击事件的流程去添加长按事件的监听,
需要注意的是 @Override
public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
hideSoftKeyboard();
int adjPosition = position - mListView.getHeaderViewsCount();
if (adjPosition >= 0) {
onItemLongClick(adjPosition, id);
}
return true;
}
实现接口的方法时候其放回值,true :在长按时,点击事件监听无效.
public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
hideSoftKeyboard();
int adjPosition = position - mListView.getHeaderViewsCount();
if (adjPosition >= 0) {
onItemLongClick(adjPosition, id);
}
return true;
}