Android實(shí)現(xiàn)GridView中ImageView動(dòng)態(tài)變換的方法
本文實(shí)例講述了Android實(shí)現(xiàn)GridView中ImageView動(dòng)態(tài)變換的方法。分享給大家供大家參考。具體如下:
使用YY影音的時(shí)候,發(fā)現(xiàn)點(diǎn)擊GridView的某一個(gè)Item,Item里面的圖標(biāo)會(huì)在按下的時(shí)候發(fā)生變換,變成另外一個(gè)圖片。
自己寫了一個(gè)類似的demo,具體步驟如下:
1、創(chuàng)建一個(gè)包含Grid的Acitity
2、創(chuàng)建item.xml 里面包含一個(gè)imageview和一個(gè)textview
3、自定義一個(gè)adapter,從baseadapter繼承
4、在getView中為每個(gè)imageView添加setOnTouchListener
代碼入下:
MainActivity.java
package com.mygriddemo;
import java.util.ArrayList;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.res.Resources;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity {
/** Called when the activity is first created. */
private GridView gv;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
gv = (GridView) findViewById(R.id.mygrid);
AddAdapter addadapter = new AddAdapter(this);
gv.setAdapter(addadapter);
}
public class AddAdapter extends BaseAdapter {
private final LayoutInflater mInflater;
private final ArrayList<ListItem> mItems = new ArrayList<ListItem>();
// public static final int ITEM_SHORTCUT = 0;
// public static final int ITEM_APPWIDGET = 1;
// public static final int ITEM_LIVE_FOLDER = 2;
// public static final int ITEM_WALLPAPER = 3;
/**
* Specific item in our list.
*/
public class ListItem {
public final CharSequence text;
public final Drawable image;
//public final int actionTag;
public final Drawable touchimage;
//, int actionTag
public ListItem(Resources res, int textResourceId, int imageResourceId,int touchImageResourceId) {
text = res.getString(textResourceId);
if (imageResourceId != -1) {
image = res.getDrawable(imageResourceId);
} else {
image = null;
}
if (touchImageResourceId != -1) {
touchimage = res.getDrawable(touchImageResourceId);
} else {
touchimage = null;
}
}
}
public AddAdapter(MainActivity launcher) {
super();
mInflater = (LayoutInflater) launcher.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// Create default actions
Resources res = launcher.getResources();
mItems.add(new ListItem(res, R.string.item1,
R.drawable.item1, R.drawable.item1back));
mItems.add(new ListItem(res, R.string.item2,
R.drawable.item2, R.drawable.item2back));
mItems.add(new ListItem(res, R.string.item3,
R.drawable.item3, R.drawable.item3back));
mItems.add(new ListItem(res, R.string.item4,
R.drawable.item4, R.drawable.item4back));
}
public View getView(int position, View convertView, ViewGroup parent) {
final ListItem item = (ListItem) getItem(position);
if (convertView == null) {
convertView = mInflater.inflate(R.layout.grid_item, parent, false);
}
final TextView textView = (TextView) convertView;//.findViewById(R.id.mygrid);
textView.setTag(item);
textView.setText(item.text);
textView.setCompoundDrawablesWithIntrinsicBounds(null, item.image, null, null);
textView.setOnTouchListener(new OnTouchListener(){
public boolean onTouch(View arg0, MotionEvent arg1) {
// TODO Auto-generated method stub
if (arg1.getAction() == MotionEvent.ACTION_DOWN){
Log.d("WeatherWidget", MotionEvent.ACTION_DOWN+"");
textView.setCompoundDrawablesWithIntrinsicBounds(null, item.touchimage, null, null);
}
else if(arg1.getAction() == MotionEvent.ACTION_UP) {
Log.d("WeatherWidget", arg1.getAction()+"");
textView.setCompoundDrawablesWithIntrinsicBounds(null, item.image, null, null);
Intent i = new Intent(MainActivity.this,Page1Activity.class);
startActivity(i);
}
return true;
}
});
return convertView;
}
public int getCount() {
return mItems.size();
}
public Object getItem(int position) {
return mItems.get(position);
}
public long getItemId(int position) {
return position;
}
}
}
main.xml代碼:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <GridView android:id="@+id/mygrid" android:layout_width="fill_parent" android:layout_height="fill_parent" android:numColumns="2" android:verticalSpacing="10dip" android:horizontalSpacing="10dip" android:stretchMode="columnWidth" android:gravity="center" > </GridView> </LinearLayout>
griditem.xml代碼:
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:minHeight="?android:attr/listPreferredItemHeight" android:layout_centerHorizontal="true" android:drawablePadding="14dip" android:paddingLeft="15dip" android:paddingRight="15dip" android:gravity="center_horizontal" />
希望本文所述對大家的Android程序設(shè)計(jì)有所幫助。
- 詳解Android使GridView橫向水平滾動(dòng)的實(shí)現(xiàn)方式
- Android開發(fā)基于ViewPager+GridView實(shí)現(xiàn)仿大眾點(diǎn)評(píng)橫向滑動(dòng)功能
- Android中實(shí)現(xiàn)多行、水平滾動(dòng)的分頁的Gridview實(shí)例源碼
- android ListView和GridView拖拽移位實(shí)現(xiàn)代碼
- Android GridView實(shí)現(xiàn)滾動(dòng)到指定位置的方法
- android中GridView的用法示例
- android GridView多選效果的實(shí)例代碼
- Android開發(fā)之使用GridView展示圖片的方法
- Android開發(fā)學(xué)習(xí)筆記 Gallery和GridView淺析
- Android GridView仿微信朋友圈顯示圖片
- Android實(shí)現(xiàn)九宮格(GridView中各項(xiàng)平分空間)的方法
- Android開發(fā)實(shí)現(xiàn)橫向列表GridView橫向滾動(dòng)的方法【附源碼下載】
相關(guān)文章
Android實(shí)現(xiàn)系統(tǒng)級(jí)懸浮按鈕
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)系統(tǒng)級(jí)懸浮按鈕的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
Android通過自定義ImageView控件實(shí)現(xiàn)圖片的縮放和拖動(dòng)的實(shí)現(xiàn)代碼
通過自定義ImageView控件,在xml布局里面調(diào)用自定的組件實(shí)現(xiàn)圖片的縮放。下面給大家分享實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧2016-10-10
基于Android實(shí)現(xiàn)一個(gè)常用的布局吸頂效果
這篇文章給大家介紹一個(gè)布局吸頂效果,一般出現(xiàn)在內(nèi)容較長頁面還嵌套著分類頁面的情況,比如電商的詳情頁嵌套分類,在頁面滑動(dòng)到tab的時(shí)候我們希望tab還能保留在頁面頂部而不被頂上去,文中有詳細(xì)的代碼示例,需要的朋友可以參考下2023-09-09
android studio 3.0 升級(jí) 項(xiàng)目遇到的問題及更改思路(問題小結(jié))
Android Studio從3.0版本新增了許多功能,當(dāng)然首當(dāng)其沖就是從3.0版本新增了對 Kotlin 開發(fā)語言的支持,除此之外還有其他一些新功能。很多小伙伴在android studio 3.0 升級(jí)項(xiàng)目遇到很多問題,下面小編給大家分享一些問題小結(jié)及解決辦法,一起看看吧2017-11-11
Android開發(fā)實(shí)現(xiàn)去除bitmap無用白色邊框的方法示例
這篇文章主要介紹了Android開發(fā)實(shí)現(xiàn)去除bitmap無用白色邊框的方法,結(jié)合實(shí)例形式給出了Android去除bitmap無用白色邊框的具體操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-11-11
android 震動(dòng)和提示音的實(shí)現(xiàn)代碼
這篇文章主要介紹了android 震動(dòng)和提示音的實(shí)現(xiàn)代碼,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12
Android底部導(dǎo)航組件BottomNavigationView
這篇文章主要介紹了Android底部導(dǎo)航組件BottomNavigationView,BottomNavigationView是相當(dāng)于一個(gè)導(dǎo)航的標(biāo)簽,但是它的形式就是像QQ微信之類的界面,至于寫出后怎樣綁定這三個(gè)界面,就得用Fragment,寫這三個(gè)頁面的布局2023-03-03
Android自定義wheelview實(shí)現(xiàn)滾動(dòng)日期選擇器
這篇文章主要為大家詳細(xì)介紹了Android自定義wheelview實(shí)現(xiàn)滾動(dòng)日期選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07

