Android Contacts源码分析二——(PeopleActivity)分析

本文承接 

Android Contacts源码分析

下面我们直接进入PeopleActivity进行分析(请阅读 

Android Contacts源码分析

,之后再阅读本文)
好了我们正式进军PeopleActivity
还是率先给出源码位置:
SourceCode/packages\apps\ContactsW2014\src\com\android\contacts\activities/PeopleActivity.java

@Override
 protected void onCreate(Bundle savedState) {
.........
createViewsAndFragments(savedState);
...............
}

private void createViewsAndFragments(Bundle savedState) {
setContentView(R.layout.people_activity);
final FragmentManager fragmentManager = getFragmentManager();
final FragmentTransaction transaction = fragmentManager.beginTransaction();
final boolean isUsingTwoPanes = PhoneCapabilityTester.isUsingTwoPanes(this);
if (isUsingTwoPanes) {
mFavoritesFragment = getFragment(R.id.favorites_fragment);
mAllFragment = getFragment(R.id.all_fragment);
mGroupsFragment = getFragment(R.id.groups_fragment);
} else {
mTabPager = getView(R.id.tab_pager);
mTabPager.setTouchDisabled(true);
mTabPagerAdapter = new TabPagerAdapter();
mTabPager.setAdapter(mTabPagerAdapter);
mTabPager.setOnPageChangeListener(mTabPagerListener);
final String FAVORITE_TAG = "tab-pager-favorite";
final String ALL_TAG = "tab-pager-all";
final String GROUPS_TAG = "tab-pager-groups";
final String PHONE_TAG = "tab-pager-phone";
mFavoritesFragment = (ContactTileListFragment)fragmentManager.findFragmentByTag(FAVORITE_TAG);
mAllFragment = (DefaultContactBrowseListFragment)fragmentManager.findFragmentByTag(ALL_TAG);
mGroupsFragment = (GroupBrowseListFragment)fragmentManager.findFragmentByTag(GROUPS_TAG);
mPhoneFragment = (PhoneFragment)fragmentManager.findFragmentByTag(PHONE_TAG);
if (mFavoritesFragment == null) {
 mFavoritesFragment = new ContactTileListFragment();
mAllFragment = new DefaultContactBrowseListFragment();
mGroupsFragment = new GroupBrowseListFragment();
mPhoneFragment = new PhoneFragment("phone");	
transaction.add(R.id.tab_pager, mFavoritesFragment, FAVORITE_TAG);
transaction.add(R.id.tab_pager, mAllFragment, ALL_TAG);
transaction.add(R.id.tab_pager, mGroupsFragment, GROUPS_TAG);
transaction.add(R.id.tab_pager, mPhoneFragment, PHONE_TAG);
}}

通过上面一段代码


我们可以知道PeopleActivity也是有四部分组成(具体见 

Android Contacts源码分析配图


手机
fragmentManager.findFragmentByTag(PHONE_TAG);

群组
fragmentManager.findFragmentByTag(GROUPS_TAG);
我的收藏

fragmentManager.findFragmentByTag(FAVORITE_TAG);

联系人
fragmentManager.findFragmentByTag(ALL_TAG);

同理 ,像我上一篇文章(传送门)所说的一样,首先,这里我们还是以MTK原装系统为案例
各手机厂商作出修改后也只是略有不同,其次这里的findFragmentByTag(PHONE_TAG);等同于上文
new PhoneFragment(“phone”);

@Override
public void onSelectedTabChanged() {
......
if(tab == TabState.PHONE)
{
if(mCallType.equals("NORMAL"))
{
Intent intent = new Intent();
intent.setClassName("com.android.contacts", "com.android.contacts.activities.DialtactsActivity");
startActivity(intent);
mActionBarAdapter.setCurrentTab(TabState.ALL, false);
finish();
}

完成跳转!
这里,继续吐槽MTK。搞什么双向跳转飞机,无端增加加载压力,影响手机使用。所以各大手机厂商一般就修改了该系统
同理,和我上一篇文章一样,我们也是选择其一作为案例
这次,我们把案例瞄准
联系人
fragmentManager.findFragmentByTag(ALL_TAG);
 private DefaultContactBrowseListFragment mAllFragment;

mAllFragment = (DefaultContactBrowseListFragment) fragmentManager.findFragmentByTag(ALL_TAG);

那么,我们还是老规矩,先进入DefaultContactBrowseListFragment
SourceCode/packages\apps\ContactsW2014\src\com\android\contacts\list/DefaultContactBrowseListFragment.java 好了,我们继续下一步

@Override
protected View inflateView(LayoutInflater inflater, ViewGroup container) {
return inflater.inflate(R.layout.contact_list_content, null);}
@Override
protected void onCreateView(LayoutInflater inflater, ViewGroup container) {super.onCreateView(inflater, container);
mAccountFilterHeader = getView().findViewById(R.id.account_filter_header_container);
 mAccountFilterHeader.setOnClickListener(mFilterHeaderClickListener);
mCounterHeaderView = (TextView) getView().findViewById(R.id.contacts_count);
total_contacts = inflater.inflate(R.layout.total_contacts, getListView(), false);
mTotalContacts = (TextView) total_contacts.findViewById(R.id.totalContactsText);

if(total_contacts!=null)
{
getListView().addFooterView(total_contacts);
}
.............
}

很明显的发现他的布局界面contact_list_content
SourceCode/packages\apps\ContactsW2014\res\layout/
contact_list_content.xml

<LinearLayout>
<LinearLayout
android:id="@+id/contactListTopBar"
>

<EditText
android:id="@+id/searchContactsEditText"/><span style="white-space:pre">		</span>//搜索联系人输入框
<ImageView
android:id="@+id/addContactsImageView"/><span style="white-space:pre">		</span>//添加联系人按钮
</LinearLayout>
<include
 android:id="@+id/account_filter_header_container"<span style="white-space:pre">		</span>
layout="@layout/account_filter_header" /><span style="white-space:pre">				</span>//过滤器账户文字TextView
<include layout="@layout/wait_cursor"/><span style="white-space:pre">			</span>//显示加载
<FrameLayout>
<view
class="com.android.contacts.widget.PinnedHeaderListView"<span style="white-space:pre">		</span>//核心联系人界面ListView
android:id="@android:id/list"
/>
<ProgressBar
android:id="@+id/search_progress"/>
</FrameLayout>
<ViewStub
android:id="@+id/footer_stub"
android:layout="@layout/footer_panel"/>
</LinearLayout>

那么至此,我们已经跟踪到了最核心的联系人列表
SourceCode/packages\apps\ContactsW2014\src\com\android\contacts\widget/PinnedHeaderListView.java
还是那句话,此次我们只涉及界面分析,至于具体的数据获取和加载。我以后有时间再做分析
这里重点指出android:id=”@+id/account_filter_header_container”
这里实现了搜索的A-Z字母排列(有需要的自己去看一下,实现过程很简单)

    原文作者:Android源码分析
    原文地址: https://blog.csdn.net/jaysong2012/article/details/40047039
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞