亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android實現簡單卡片布局

2019-10-21 21:37:15
字體:
來源:轉載
供稿:網友

GoogleNow是Android4.1全新推出的一款應用他,它可以全面了解你的使用習慣,并為你提供現在或者未來可能用到的各種信息,GoogleNow提供的信息關聯度較高,幾乎是瞬間返回答案,總而言之,GoogleNow是Google提出的全新搜索概念。當然,GoogleNow最為引人注目的當屬它的卡片式設計。Google自家應用紛紛采用卡片布局(Google Now,Google Plus,Google Play)。

Android,卡片布局

Android,卡片布局

在最新的QQ空間、新浪微博、豌豆莢中也可以見到卡片式設計的影子

Android,卡片布局

Android,卡片布局

下面介紹一種簡單實現卡片布局的方式

list_item.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="wrap_content" tools:context=".MainActivity"  android:background="@drawable/radius_bg">  <ImageView android:id="@+id/iv_logo" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_margin="8dp" android:src="@drawable/ic_launcher" />  <TextView android:id="@+id/tv_name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignTop="@id/iv_logo" android:layout_toRightOf="@id/iv_logo" android:text="@string/hello_world" android:textSize="16sp" />  <TextView android:id="@+id/tv_desc" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/tv_name" android:layout_marginTop="5dp" android:layout_toRightOf="@id/iv_logo" android:text="@string/hello_world" android:textSize="13sp" /> </RelativeLayout>

自定義Shape圖片radius_bg.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="3dp"/>  <solid android:color="#ffffff"/> </shape>

主界面布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"  android:background="#e6e6e6">  <ListView  android:id="@+id/mListView"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:divider="@android:color/transparent" android:paddingLeft="10dp" android:paddingRight="10dp" android:paddingTop="2dp" android:paddingBottom="2dp" android:dividerHeight="10dp" >  </ListView>  </RelativeLayout>

Card實體

package com.example.carduitest.model; public class Card { private String name; private String desc; private int icon;  public Card(String name, String desc) { this.name = name; this.desc = desc; }  public String getName() { return name; } public void setName(String name) { this.name = name; } public String getDesc() { return desc; } public void setDesc(String desc) { this.desc = desc; } public int getIcon() { return icon; } public void setIcon(int icon) { this.icon = icon; }}

自定義適配器

package com.example.carduitest.adapter; import java.util.List; import com.example.carduitest.R;import com.example.carduitest.model.Card;import android.content.Context;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.TextView; public class CardAdapter extends BaseAdapter { private List<Card> data; private Context context; private LayoutInflater mInflater;  public CardAdapter(List<Card> data, Context context) { this.data = data; this.context = context; mInflater = LayoutInflater.from(context); }  @Override public int getCount() { // TODO Auto-generated method stub return data.size(); }  @Override public Object getItem(int position) { // TODO Auto-generated method stub return data.get(position); }  @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; }  @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if(convertView==null){ convertView = mInflater.inflate(R.layout.list_item, null);  holder = new ViewHolder(); holder.tv_name = (TextView) convertView.findViewById(R.id.tv_name); holder.tv_desc = (TextView) convertView.findViewById(R.id.tv_desc);  convertView.setTag(holder); }else{ holder = (ViewHolder) convertView.getTag(); }  Card card = data.get(position); holder.tv_name.setText(card.getName()); holder.tv_desc.setText(card.getDesc());  return convertView; }  static class ViewHolder{ TextView tv_name; TextView tv_desc; } }
package com.example.carduitest; import java.util.ArrayList;import java.util.List; import com.example.carduitest.adapter.CardAdapter;import com.example.carduitest.model.Card; import android.os.Bundle;import android.app.Activity;import android.view.Menu;import android.widget.ListView; public class MainActivity extends Activity {  private List<Card> data = new ArrayList<Card>();  @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main);  initData(); ListView mListView = (ListView) findViewById(R.id.mListView);  CardAdapter mAdapter = new CardAdapter(data,this); mListView.setAdapter(mAdapter); }  private void initData() {  for(int i=0;i<50;i++){ Card card = new Card("Card UI Example "+i, "Very Good"); data.add(card); } }  @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }

運行效果如下:

p>Android,卡片布局

當然啦,Github上面也有專門的實現card的library,這里列舉兩個不錯的library

cardslib:地址

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
少妇高潮久久77777| 国产精品日韩欧美综合| 久久99国产精品久久久久久久久| 美日韩在线视频| 亚洲综合精品一区二区| 欧美做受高潮1| 日韩的一区二区| 久热精品视频在线观看一区| 亚洲精品自拍偷拍| 久久久亚洲国产天美传媒修理工| 亚洲丁香久久久| 欧美日产国产成人免费图片| 91亚洲国产成人精品性色| 91国内在线视频| 久久影视电视剧免费网站| 亚洲色图15p| 欧美成年人网站| 亚洲日本成人网| 日韩黄色在线免费观看| 久久人人爽人人爽人人片av高请| 国产亚洲精品一区二555| 精品国内产的精品视频在线观看| 色综合导航网站| 这里只有精品久久| 久久久这里只有精品视频| 欧美日韩另类字幕中文| 国产97在线|亚洲| 久久这里只有精品视频首页| 久久综合久久88| 国产精品久久久久久久久久久久久久| 亚洲日韩中文字幕| 亚洲精品不卡在线| 日韩精品免费看| 久久综合伊人77777蜜臀| 亚洲一区二区中文字幕| 中文字幕日韩电影| 亚洲精品久久久久久久久久久久| 欧美精品在线免费播放| 欧美性猛交xxxx黑人| 欧美自拍视频在线观看| 亚洲午夜精品久久久久久久久久久久| 中文日韩在线观看| 亚洲韩国日本中文字幕| 97国产精品视频| 91国自产精品中文字幕亚洲| 国产精品免费视频久久久| 国产亚洲欧美日韩一区二区| 国产精品99久久久久久www| 欧美性一区二区三区| 亚洲国产毛片完整版| 青青久久av北条麻妃海外网| 亚洲综合成人婷婷小说| 国产视频观看一区| 国产精品亚洲网站| 中文字幕一区日韩电影| 亚洲精品国产综合久久| 中文字幕久精品免费视频| 日韩欧美在线字幕| 亚洲国产婷婷香蕉久久久久久| 欧美性猛交xxxxx水多| 一本色道久久88精品综合| 亚洲精品白浆高清久久久久久| 欧美电影免费观看高清| 国产亚洲成av人片在线观看桃| 欧美丰满少妇xxxxx做受| 亚洲国产欧美一区| 亚洲激情成人网| 亚洲男人7777| 欧美视频13p| 亚洲精选中文字幕| 欧美性xxxxxxxxx| 亚洲japanese制服美女| 九九视频直播综合网| 色午夜这里只有精品| www国产亚洲精品久久网站| 国产日本欧美一区| 久久久av一区| 日韩在线www| 国产女人18毛片水18精品| 亚洲国产小视频在线观看| 日韩在线观看电影| 成人国产精品日本在线| 欧美大尺度激情区在线播放| 538国产精品一区二区免费视频| 另类天堂视频在线观看| 国产精品免费在线免费| 国内精品一区二区三区四区| 92裸体在线视频网站| 国产精品无av码在线观看| 日韩av免费在线播放| 亚洲精品电影网在线观看| 91爱爱小视频k| 久久精品国产2020观看福利| 亚洲小视频在线观看| 欧美日韩福利在线观看| 性欧美办公室18xxxxhd| 国产91免费观看| 亚洲最大福利视频网| 国产成人精品一区二区三区| 66m—66摸成人免费视频| 国产精品视频最多的网站| 性欧美xxxx| 国产91ⅴ在线精品免费观看| 国产日韩视频在线观看| 日韩高清免费观看| 国产91免费观看| 欧美二区乱c黑人| 日韩美女av在线| 草民午夜欧美限制a级福利片| 国产成人在线一区二区| 久久躁狠狠躁夜夜爽| 亚洲日本欧美中文幕| 欧美在线性视频| 欧美国产日韩一区二区在线观看| 视频直播国产精品| 美女扒开尿口让男人操亚洲视频网站| 国模吧一区二区三区| 亚洲人成绝费网站色www| 在线国产精品视频| 欧美精品在线第一页| 欧美性xxxx极品高清hd直播| 亚洲影院污污.| 欧美人交a欧美精品| 亚洲人成网在线播放| 国产精品国产三级国产专播精品人| 国产精品老女人精品视频| 免费97视频在线精品国自产拍| 国产精品久久久久久久一区探花| 久久免费观看视频| 亚洲欧美日韩第一区| 色诱女教师一区二区三区| 欧美性色19p| 国产欧美一区二区白浆黑人| 亚洲精品久久久久| 亚洲精品99久久久久| 欧美成人午夜剧场免费观看| 国产精品第一第二| 亚洲欧美日韩成人| 神马久久桃色视频| 欧美人交a欧美精品| 国产福利成人在线| 亚洲黄色有码视频| 91亚洲精品久久久| 57pao成人国产永久免费| 成人av资源在线播放| 最近2019中文字幕大全第二页| 91午夜理伦私人影院| 狠狠干狠狠久久| 91精品国产高清| 日本精品久久中文字幕佐佐木| 成人日韩在线电影| 欧美乱妇高清无乱码| 欧美一区二区大胆人体摄影专业网站| 亚洲人午夜精品| 日韩亚洲欧美成人| 97精品视频在线播放| 亚洲国内高清视频| 黑人与娇小精品av专区| 欧美交受高潮1| 亚洲国产一区二区三区四区| 国产亚洲精品久久久优势| 亚洲激情中文字幕| 亚洲精品一区久久久久久| 亚洲日韩欧美视频一区|