ListView

V##編寫代碼listView #####新建一個(gè)java自動(dòng)生成xml ####java里面打: ``` package com.example.palace; import android.app.Activity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.widget.GridView; import android.widget.ListView; public class MainActivity extends Activity { //GridView(網(wǎng)格布局)中android:numColumns="3"給他設(shè)置了三列 // 如果不設(shè),默認(rèn)的是一列(效果就會(huì)和listView一樣) GridView gridView; //Palace類,繼承了BaseAdapter(基礎(chǔ)適配器) Palace palace; // 定義一個(gè)name的字符串用來表示應(yīng)用名稱 String name[]={"家園衛(wèi)士","安裝包","游戲盒子", "鏈接電腦","記事本","垃圾箱","流量管理","軟件修復(fù)","系統(tǒng)設(shè)置"}; // 定義一個(gè)icon的數(shù)字int類型用來把圖片的地址引用過來 int[] icon={R.drawable.widget01,R.drawable.widget02,R.drawable.widget03, R.drawable.widget04,R.drawable.widget05,R.drawable.widget06, R.drawable.widget07,R.drawable.widget08,R.drawable.widget09,}; //重寫方法 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // ")f"暗寫 // 初始化對GridView的操作(findViewById是用來指定id的!) gridView=(GridView)findViewById(R.id.gridview); // new新建了一個(gè)Palace因?yàn)閕nflate要加載布局所以要穿一個(gè)Context上下文 palace = new Palace(this, name, icon); // 設(shè)置適配器 gridView.setAdapter(palace); } } ``` ####xml里寫 ``` android:id="@+id/gridview" xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="@string/hello_world" android:numColumns="3" > ``` ####在新建的Palace里面打: ``` package com.example.palace; import android.content.Context; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.TextView; public class Palace extends BaseAdapter { String[] mname;//定義一個(gè)接受構(gòu)造傳入的應(yīng)用名 int[] icon; //定義一個(gè)接受構(gòu)造傳入的圖片ID數(shù)組 Context context;//接受上下文 //上面都是通過構(gòu)造來傳遞 public Palace(Context context,String[] mname, int[] icon) { super(); this.mname = mname; this.icon = icon; this.context=context; } //設(shè)置條目的總數(shù)(一般以集合的長度,因?yàn)榧祥L度可變) @Override public int getCount() { // TODO Auto-generated method stub return icon.length; } //返回指定下標(biāo)對應(yīng)的數(shù)據(jù)對象 @Override public Object getItem(int position) { // TODO Auto-generated method stub return icon[position]; } //返回每個(gè)條目的ID @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } //返回指定下標(biāo)所對應(yīng)的Item的View對象 // position下標(biāo) // convertView可以復(fù)用的緩存Item視圖對象, 前n+1個(gè)為null // parent ViewGroup對象 @Override public View getView(int position, View convertView, ViewGroup parent) { // 優(yōu)化 pag pbg =null;//else訪問到同一個(gè) if(convertView==null){//如果顯示的條目等于空是我再給他賦值, // 不然會(huì)一直賦值導(dǎo)致內(nèi)存溢出 pbg =new pag();//新建一個(gè)存放數(shù)據(jù)的 //加載一個(gè)hen布局賦值到convertView,Item的視圖對象 convertView=View.inflate(context, R.layout.hen, null); // convertView.findViewById//必須明寫 pbg.image=(ImageView) convertView.findViewById(R.id.image); // hen里面的image和text pbg.text=(TextView) convertView.findViewById(R.id.text); // 有了布局再設(shè)置里面的控件.(pbg設(shè)置控件) convertView.setTag(pbg); }else{ //如果已經(jīng)加載的顯示的條目有值, // 獲取 pbg= (pag) convertView.getTag(); } // 給控件賦值 pbg.image.setImageResource(icon[position]); pbg.text.setText(mname[position]); return convertView; } class pag{//數(shù)據(jù)包 ImageView image; TextView text; } } ``` ####hen.xml里面寫 ``` android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > android:id="@+id/image" android:layout_width="50dp" android:layout_marginTop="5dp" android:layout_gravity="center" android:layout_height="50dp" /> android:id="@+id/text" android:textSize="20dp" android:layout_marginTop="5dp" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" /> ``` ####效果圖 ![image.png](https://upload-images.jianshu.io/upload_images/11863487-692822258abcf209.png?imageMogr2/auto-orient/strip|imageView2/2/w/1240)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,527評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,687評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,640評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,957評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,682評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,011評論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,009評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,183評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,714評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,435評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,665評論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,148評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,838評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,251評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,588評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,379評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,627評論 2 380

推薦閱讀更多精彩內(nèi)容