導航是移動應用最重要的方面之一,對用戶體驗是良好還是糟糕起著至關重要的作用。好的導航可以讓一款應用更加易用并且讓用戶快速上手。相反,糟糕的應用導航很容易讓人討厭,并遭到用戶的拋棄。為了打造流暢的用戶導航體驗,我們不得不依賴智能手機最常見的一個功能:觸摸。
觸摸改變應用程序的視圖是現在最流行一種導航設計。在本博客中,我們將經過必要的幾步來實現應用內的橫向滑動導航。
本文毫無遲疑地使用了代碼優先的方法 。讓我們看一下滑動導航需要完成的主要代碼片段。
<span >public class MainActivity extends Activity {
SectionsPagerAdapter mSectionsPagerAdapter;
ViewPager mViewPager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mSectionsPagerAdapter = new SectionsPagerAdapter(getFragmentManager());
mViewPager = (ViewPager) findViewById(R.id.pager);
mViewPager.setAdapter(mSectionsPagerAdapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
public class SectionsPagerAdapter extends FragmentPagerAdapter {
public SectionsPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
switch (position) {
case 0:
return new MoviesFragment();
case 1:
return new TVShowsFragment();
case 2:
return new SongsFragment();
}
return null;
}
@Override
public int getCount() {
// Show 3 total pages.
return 3;
}
}
}</span>我們的Main Activity包含了ViewPager組件,它封裝了幾個不同的菜單屏,每一屏有一個不同的fragment。我們要做的第一件事就是聲明一個FragmentPagerAdapter,用它在不用的菜單fragment間切換。正如你在上面代碼中看到的,我們聲明了一個SectionsPagerAdapter,它繼承自FragmentPagerAdaper類。然后在onCreate方法中將它實例化.
對于SectionsPagerAdapter類,需要重寫兩個方法。第一個方法是getCount()方法,它返回導航的的fragment數量。第二個也是最中的getItem()方法,它用來實例化并返回相關的fragment,它的顯示基于它在菜單中的位置。
這些不同的菜單fragment必須繼承fragment類,然后填充自己的布局,讓我們看下其中的一個類:
<span >public class MoviesFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.movies_fragment, container, false);
return rootView;
}
}</span>把這些放到一起就為我們的安卓應用程序創建了一個非常直觀的滑動的導航。我們辛苦完成的Native Ads在不影響用戶體驗的前提下可以很好的讓應用程序盈利??焖偌稍?、In-stream和可定制的廣告單元,這兒可以檢出Native Ads的SDK,
這兒可以得到這篇教程中完整的源代碼:SwipeNavigationExample。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。