聲明:學(xué)習(xí)的書籍《Android應(yīng)用開發(fā)揭秘》,這里記錄學(xué)習(xí)該書籍的日志,引用的相關(guān)代碼與總結(jié)描述,沒有商業(yè)的用途,完全是自我學(xué)習(xí)的一個記錄,剛剛學(xué)習(xí)不可避免會出現(xiàn)很多問題,若是有錯誤還請大家多多批評。
繼續(xù)學(xué)習(xí)《android應(yīng)用開發(fā)揭秘》這本書,這里把基礎(chǔ)控件的學(xué)習(xí)進(jìn)行了分類,下面兩篇博客主要是一些常用的效果
一、 拖動效果(Gallery)
拖動效果是現(xiàn)在智能手機的一個不可缺少的功能,Android平臺中實現(xiàn)拖動效果,主要是使用了Gallery控件,Gallery英文是畫廊的意思,顧名思義存放這顯示的圖片,存放圖片資源容器是繼承自BaseAdapter類的派生類。當(dāng)然我們也可以通過setOnItemClickListener監(jiān)聽其事件。
【注意】Gallery 組件一般用于顯示圖像列表,因此也可稱相冊組件 Gallery 與GridView 的區(qū)別是Gallery只能水平顯示一行,而且支持水平滑動效果。也就是說,單擊、選中或拖動Gallery 中的圖像,Gallery中的圖像列表會根據(jù)不同的情況向左或右移動,直到顯示最后一個圖像為止.
實例分析:基于上述介紹,把要顯示的圖片資源索引存在一個int類型數(shù)組中,并且要顯示哪個圖片,通過setImageResource方法來設(shè)置ImageView要顯示的圖片。
關(guān)鍵源碼:
main.xml布局文件:
<?xml version="1.0" encoding="utf-8"?>
<Gallery
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/Gallery01"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
/>
注意,以下ImageAdapter類繼承自BaseAdapter,并重寫其方法
public class ImageAdapter extends BaseAdapter {
private Context mContext; // 定義Context
// 定義整型數(shù)組 即圖片源
private Integer[] mImageIds = {
R.drawable.img1,
R.drawable.img2,
R.drawable.img3,
R.drawable.img4,
R.drawable.img5,
R.drawable.img6,
R.drawable.img7,
R.drawable.img8,
};
public ImageAdapter(Context c) {
this.mContext = c;
}
//獲取圖片個數(shù)
public int getCount() {
return mImageIds.length;
}
//獲取圖片在圖庫的位置
public Object getItem(int position) {
return position;
}
// 獲取圖片ID
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent{
ImageView imageview = new ImageView(mContext);
//給ImageView設(shè)置資源
imageview.setImageResource(mImageIds[position]);
//設(shè)置布局圖片120x120顯示
imageview.setLayoutParams(new Gallery.LayoutParams(120,120));
//設(shè)置顯示比例類型
imageview.setScaleType(ImageView.ScaleType.FIT_CENTER);
return imageview;
}
}
而實際Activity01中只要把adapter付給Gallery對象,并設(shè)置監(jiān)聽事件即可“
//獲得Gallery對象
Gallery g = (Gallery) this.findViewById(R.id.Gallery01);
//添加ImageAdapter給Gallery對象
g.setAdapter(new ImageAdapter(this));
//設(shè)置Gallery對象的監(jiān)聽事件
g.setOnItemClickListener(new OnItemClickListener(){
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
Toast.makeText(Examples_04_17Activity.this,"你選擇了"+(arg2+1)+" 號圖片", Toast.LENGTH_SHORT).show();}
});
實例效果:
二、 切換圖片(ImageSwitcher)
該功能類似于很多圖片瀏覽器,上一張下一張圖片進(jìn)行切換,ImageSwitcher在實現(xiàn)該效果時,需要設(shè)置一個 ViewSwitcher.ViewFactory ,注意ViewSwitcher.ViewFactory是個接口,目的:在視圖轉(zhuǎn)換器(ViewSwitcher)中創(chuàng)建視圖。并通過makeView()方法來顯示圖片。
公共方法:public abstract View makeView ()
創(chuàng)建一個用于添加到視圖轉(zhuǎn)換器(ViewSwitcher)中的新視圖
關(guān)鍵源碼:
private ImageSwitcher m_Switcher; //創(chuàng)建ImageSwitcher對象
private static int index = 0; //索引
private static final int BUTTON_DOWN_ID = 0x123456; //“下一頁”按鈕ID
private static final int BUTTON_UP_ID = 0x123457; //“上一頁”按鈕ID
private static final int SWITCHER_ID = 0x123458; //ImageSwitcher對象的ID
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout main_view = new LinearLayout(this);
m_Switcher = new ImageSwitcher(this); //創(chuàng)建ImageSwitcher對象
main_view.addView(m_Switcher); //在線性布局中添加ImageSwitcher視圖
m_Switcher.setId(SWITCHER_ID); //設(shè)置ImageSwitcher對象的ID
m_Switcher.setFactory(this); //設(shè)置ImageSwitcher對象的數(shù)據(jù)源
m_Switcher.setImageResource(imagelist[index]);
setContentView(main_view); //設(shè)置顯示上面創(chuàng)建的線性布局
Button next = new Button(this); //創(chuàng)建“下一張”按鈕
next.setId(BUTTON_DOWN_ID);
next.setText("下一張");
next.setOnClickListener(this);
LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(100, 100);
main_view.addView(next, param);
Button pre = new Button(this); //創(chuàng)建“上一張”按鈕
pre.setId(BUTTON_UP_ID);
pre.setText("上一張");
pre.setOnClickListener(this);
main_view.addView(pre, param);
}
//事件監(jiān)聽、處理
public void onClick(View v) {
switch(v.getId()){
case BUTTON_DOWN_ID: //下一頁
index++;
if (index >= imagelist.length){
index = 0;
}
//ImageSwitcher對象資源索引
m_Switcher.setImageResource(imagelist[index]);
break;
case BUTTON_UP_ID: //上一頁
index--;
if (index < 0){
index = imagelist.length - 1;
}
//ImageSwitcher對象資源索引
m_Switcher.setImageResource(imagelist[index]);
break;
default:
break;
}
}
@Override
public View makeView() {
return new ImageView(this); //將所有圖片通過ImageView來顯示
}
【擴展點】ViewSwitcher
一、結(jié)構(gòu)
public class ViewSwitcher extends ViewAnimator
Java .lang.Object
android.view.View
android.view.ViewGroup
android.widget.FrameLayout
android.widget.ViewAnimator
android.widget.ViewSwitcher
已知直接子類:ImageSwitcher, TextSwitcher
二、概述
在兩個視圖間轉(zhuǎn)換時顯示動畫,有一個可以創(chuàng)建這些視圖的工廠類。你可以用工廠來創(chuàng)建這些視圖,也可以自己創(chuàng)建。一個ViewSwitcher只允許包含兩個子視圖,且一次僅能顯示一個。
(譯者注:與ViewFlipper類相似,但該類不常用,常用其兩個子類ImageSwitcher:轉(zhuǎn)換圖片時增加動畫效果; TextSwitcher: 轉(zhuǎn)換文字時增加動畫效果; 其實例見apidemos中ImageSwitcher實例和TextSwitcher實例)
三、內(nèi)部類
interface ViewSwitcher.ViewFactory
在一個ViewSwitcher里創(chuàng)建視圖
…………….
五、公共方法
public void setFactory (ViewSwitcher.ViewFactory factory)
設(shè)置用來生成將在視圖轉(zhuǎn)換器中切換的兩個視圖的工廠。也可以調(diào)用兩次 addView(android.view.View, int, android.view.ViewGroup.LayoutParams)來替代使用工廠的方法。
參數(shù): factory 用來生成轉(zhuǎn)換器內(nèi)容的視圖工廠
引用自: http://dev.10086.cn/cmdn/wiki/index.php?doc-view-4764.html
實例效果:
三、網(wǎng)格視圖(GridVIew)
網(wǎng)格視圖的排列方式與矩陣類似,它所需要顯示元素同樣適用BaseAdapter來實現(xiàn),適用方法,類似于Gallery控件
關(guān)鍵代碼:
//取得GridView對象
GridView gridview = (GridView) this.findViewById(R.id.gridview);
//添加元素給gridview
gridview.setAdapter(new ImageAdapter(this));
gridview.setBackgroundResource(R.drawable.bg0);
//事件監(jiān)聽
gridview.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View v, int position, long id){
Toast.makeText(Activity01.this, "你選擇了" + (position + 1) + " 號圖片", Toast.LENGTH_SHORT).show();
}
});
四、卷軸視圖(ScrollView)
卷軸視圖主要用于,一頁數(shù)據(jù)顯示不開后,需要滾動來顯示的視圖。
實例分析:ScrollView定義個線性布局,線性布局中一個TextView以及一個Button,每點擊一次按鈕就增加一個線性布局。
關(guān)鍵源碼:
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/ScrollView01"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:scrollbars="none" >
......
</ScrollView>
在按鈕點擊事件里:
......
//改變默認(rèn)焦點切換
buttonView.setOnKeyListener(mNewButtonKeyListener);
//投遞一個消息進(jìn)行滾動
mHandler.post(mScrollToBottom);
private Runnable mScrollToBottom = new Runnable() {
@Override
public void run(){
int off = mLayout.getMeasuredHeight() - mScrollView.getHeight();
if (off > 0) {
mScrollView.scrollTo(0, off);//設(shè)置當(dāng)前視圖滾動到的位置
}
}
};
今天學(xué)習(xí)到P101頁
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

