編輯:關於Android編程
我們先來谷歌官方文檔對viewpager的介紹,該類允許用戶通過頁面翻轉左右的數據,需要通過實現PagerAdapter適配器來生成視圖顯示的頁面。因為注意這個類是早期設計和開發的,API可能會改變,並在以後更新兼容庫,到時候我們需要做相應的處理。ViewPager最常用於結合Fragment,這是一個方便的方式來供應和管理每個頁面的生命周期,我們後面的博客介紹相關的內容,今天我們先來簡單實現viewpager的功能。
MainAcitivity的代碼
package com.example.f10_viewpager; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.app.Activity; import android.support.v4.view.PagerAdapter; import android.support.v4.view.PagerTabStrip; import android.support.v4.view.ViewPager; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; public class MainActivity extends Activity { private View view1, view2, view3;// 需要滑動的頁卡 private ViewPager viewPager; private PagerTabStrip pagerTabStrip; private ListviewList;// 把需要滑動的頁卡添加到這個list中 private List titleList;// viewpager的標題 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 像普通控件一樣先初始化 viewPager = (ViewPager) findViewById(R.id.viewpager); pagerTabStrip = (PagerTabStrip) findViewById(R.id.pagertab); pagerTabStrip.setDrawFullUnderline(false);//設置下劃線不整頁顯示 pagerTabStrip.setTextSpacing(1000);//設置標題之間的距離 initView(); MyAdapter pagerAdapter = new MyAdapter(); viewPager.setAdapter(pagerAdapter); } //填充布局,設置每一頁的標題 private void initView() { view1 = findViewById(R.layout.layout1); view2 = findViewById(R.layout.layout2); view3 = findViewById(R.layout.layout3); viewList = new ArrayList ();// 將要分頁顯示的View裝入數組中 viewList.add(view1); viewList.add(view2); viewList.add(view3); titleList = new ArrayList ();// 每個頁面的Title數據 titleList.add("第一個頁面"); titleList.add("第二個頁面"); titleList.add("第三個頁面"); } public class MyAdapter extends PagerAdapter { @Override public boolean isViewFromObject(View arg0, Object arg1) { return arg0 == arg1; } @Override public int getCount() { return viewList.size(); } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView(viewList.get(position)); } @Override public int getItemPosition(Object object) { return super.getItemPosition(object); } @Override public CharSequence getPageTitle(int position) { return titleList.get(position); } // 將每一頁的布局填充如ViewGroup容器中 @Override public Object instantiateItem(ViewGroup container, int position) { container.addView(viewList.get(position)); return viewList.get(position); } }; }
Device Administration對於這個應用,市場上很多,但是看一下評論就知道效果有多差了,因為99%一鍵鎖屏應用沒辦法卸載。今天就開發一個小應用,實現輕松點擊
按照我一開始的打算,上面一篇文章應該是“Android動畫總結系列(5)——屬性動畫源碼分析”,不過屬性動畫源碼分析寫起來
一.這一篇我們要從網絡為首頁加載數據,解析數據,並為各個組件設置數據。我們先來看看HomePage的代碼,邏輯後面分析。代碼看起雖然挺多的,邏輯卻沒有幾步。public
下拉刷新和上拉加載的listview的實現。(1)效果展示:首先看下大致的效果:(2) 具體使用:接著看一下怎麼使用的:2.1 在layout中定義 DropDow