編輯:關於Android編程
本文實例講述了Android編程之九宮格實現方法。分享給大家供大家參考,具體如下:
顯示九宮格需要用GridView , 要顯示每個格子中的視圖有兩種方式,第一種方式是做成xml文件,再將xml文件做成視圖。第二種方式就是在代碼中構建出這樣一種布局,這裡采用第一種方式來實現:
GridView:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <!-- id gv_all 寬高都是填充父窗體 numcolums 為3 水平控件的距離 10px 垂直距離是10px gridview 離底部58px 離頂部28px 離左邊5px 離右邊5px --> <GridView android:id="@+id/gv_all" android:layout_height="fill_parent" android:layout_width="fill_parent" android:numColumns="3" android:horizontalSpacing="10px" android:verticalSpacing="10px" android:layout_marginBottom="58px" android:layout_marginTop="28px" android:layout_marginLeft="5px" android:layout_marginRight="5px" ></GridView> </RelativeLayout>
視圖:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="90px" android:layout_height="90px"> <ImageView android:layout_width="64px" android:layout_height="64px" android:layout_gravity="center_horizontal" android:id="@+id/main_gv_iv" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:textSize="16px" android:textColor="#FFF" android:id="@+id/main_gv_tv" /> </LinearLayout>
初始化:
public class MainActivity extends Activity { public static final String TAG = "MainActivity"; GridView maingv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //全屏 getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); setContentView(R.layout.mainactivity); //獲取到GridView maingv = (GridView) this.findViewById(R.id.gv_all); //給gridview設置數據適配器 maingv.setAdapter(new MainGridViewAdapter(this)); //點擊事件 maingv.setOnItemClickListener(new MainItemClickListener()); } private class MainItemClickListener implements OnItemClickListener{ /** * @param parent 代表當前的gridview * @param view 代表點擊的item * @param position 當前點擊的item在適配中的位置 * @param id 當前點擊的item在哪一行 */ public void onItemClick(AdapterView<?> parent, View view, int position, long id) { switch (position) { case 0: Intent intent = new Intent(MainActivity.this,LostProtectedActivity.class); startActivity(intent); break; } } } }
設置數據適配器 :
// 完成gridview 數據到界面的適配 public class MainGridViewAdapter extends BaseAdapter { private static final String TAG = "MainGridViewAdapter"; private String[] names = {"手機防盜","通訊衛士","軟件管理","任務管理","上網管理","手機殺毒","系統優化","高級工具","設置中心"}; private int[] icons = {R.drawable.safe,R.drawable.callmsgsafe,R.drawable.app,R.drawable.taskmanager,R.drawable.netmanager,R.drawable.trojan,R.drawable.sysoptimize,R.drawable.atools,R.drawable.settings}; private Context context; LayoutInflater infalter; public MainGridViewAdapter(Context context) { this.context = context; //方法1 通過系統的service 獲取到 試圖填充器 //infalter = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); //方法2 通過layoutinflater的靜態方法獲取到 視圖填充器 infalter = LayoutInflater.from(context); } // 返回gridview裡面有多少個條目 public int getCount() { return names.length; } //返回某個position對應的條目 public Object getItem(int position) { return position; } //返回某個position對應的id public long getItemId(int position) { return position; } //返回某個位置對應的視圖 public View getView(int position, View convertView, ViewGroup parent) { Log.i(TAG,"GETVIEW "+ position); //把一個布局文件轉換成視圖 View view = infalter.inflate(R.layout.mainactivity_item, null); ImageView iv = (ImageView) view.findViewById(R.id.main_gv_iv); TextView tv = (TextView) view.findViewById(R.id.main_gv_tv); //設置每一個item的名字和圖標 iv.setImageResource(icons[position]); tv.setText(names[position]); return view; } }
希望本文所述對大家Android程序設計有所幫助。
其實ViewFlipper工作機制很簡單,如上圖,就是將添加到ViewFlipper中的子View按照順序定時的顯示是其中一個子View,其他的子View設置為Gone狀
一 、搭建Android Studio 安裝環境 二、安裝版本控制工具搭建好Android Studio後,開發過程中我們通常會用到版本控制工具來管理我們的代碼
菜鳥起飛記android launchmode 使用場景Activity一共有以下四種launchMode:1.standard2.singleTop3.singleTa
目標效果: 程序運行出現圖一walker的歡迎界面,從模糊變清晰,過了幾秒自動跳到圖二的導航界面,下邊有小圓點表示第幾個頁面,第四個導航頁面有一個Go按鈕,點擊跳轉到