zoukankan      html  css  js  c++  java
  • Android的GridView和Gallery结合Demo

    Android的GridView和Gallery结合Demo

    Demo介绍:首页是一个GridView加载图片,竖屏时显示3列图片,横屏时显示4列图片;并且对图片进行大小限制和加灰色边框处理。

    点击某一张图片,会链接到Gallery页面,由于Android自带的Gallery控件滑动效果很不好(滑动一次会加载好多张图片),这里对Gallery进行了扩展,滑动一次只加载一张图片。

    Demo效果如下:

     

    1、首页Activity页面,GridViewActivity.java介绍:

      1 public class GridViewActivity extends Activity {
      2     private DisplayMetrics dm;
      3     private GridImageAdapter ia;
      4     private GridView g;
      5     private int imageCol = 3;
      6  
      7     @Override
      8     protected void onCreate(Bundle savedInstanceState) {
      9         // TODO Auto-generated method stub
     10         super.onCreate(savedInstanceState);
     11         // requestWindowFeature(Window.FEATURE_NO_TITLE);
     12         ia = new GridImageAdapter(this);
     13         setContentView(R.layout.mygridview);
     14         g = (GridView) findViewById(R.id.myGrid);
     15         g.setAdapter(ia);
     16         g.setOnItemClickListener(new OnItemClick(this));
     17         // 得到屏幕的大小
     18         dm = new DisplayMetrics();
     19         getWindowManager().getDefaultDisplay().getMetrics(dm);
     20  
     21     }
     22  
     23     /**
     24      * 屏幕切换时进行处理 如果屏幕是竖屏,则显示3列,如果是横屏,则显示4列
     25      */
     26     @Override
     27     public void onConfigurationChanged(Configuration newConfig) {
     28         try {
     29  
     30             super.onConfigurationChanged(newConfig);
     31             // 如果屏幕是竖屏,则显示3列,如果是横屏,则显示4列
     32             if (this.getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE) {
     33                 imageCol = 4;
     34             } else if (this.getResources().getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT) {
     35                 imageCol = 3;
     36             }
     37             g.setNumColumns(imageCol);
     38             g.setAdapter(new ImageAdapter(this));
     39             // ia.notifyDataSetChanged();
     40         } catch (Exception ex) {
     41             ex.printStackTrace();
     42         }
     43     }
     44  
     45     /**
     46      *
     47      * @author 空山不空 点击具体的小图片时,会链接到GridViewActivity页面,进行加载和展示
     48      */
     49     public class OnItemClick implements OnItemClickListener {
     50         public OnItemClick(Context c) {
     51             mContext = c;
     52         }
     53  
     54         @Override
     55         public void onItemClick(AdapterView aview, View view, int position,
     56                 long arg3) {
     57             Intent intent = new Intent();
     58             intent.setClass(GridViewActivity.this, GalleryActivity.class);
     59             intent.putExtra("position", position);
     60             GridViewActivity.this.startActivity(intent);
     61         }
     62  
     63         private Context mContext;
     64     }
     65  
     66     /**
     67      *
     68      * @author 空山不空 设置GridView的图片适配器
     69      */
     70     public class GridImageAdapter extends BaseAdapter {
     71  
     72         Drawable btnDrawable;
     73  
     74         public GridImageAdapter(Context c) {
     75             mContext = c;
     76             Resources resources = c.getResources();
     77             btnDrawable = resources.getDrawable(R.drawable.bg);
     78         }
     79  
     80         public int getCount() {
     81             return ImageSource.mThumbIds.length;
     82         }
     83  
     84         public Object getItem(int position) {
     85             return position;
     86         }
     87  
     88         public long getItemId(int position) {
     89             return position;
     90         }
     91  
     92         public View getView(int position, View convertView, ViewGroup parent) {
     93             ImageViewExt imageView;
     94  
     95             if (convertView == null) {
     96                 imageView = new ImageViewExt(mContext);
     97                 // 如果是横屏,GridView会展示4列图片,需要设置图片的大小
     98                 if (imageCol == 4) {
     99                     imageView.setLayoutParams(new GridView.LayoutParams(
    100                             dm.heightPixels / imageCol - 6, dm.heightPixels
    101                                     / imageCol - 6));
    102                 } else {// 如果是竖屏,GridView会展示3列图片,需要设置图片的大小
    103                     imageView.setLayoutParams(new GridView.LayoutParams(
    104                             dm.widthPixels / imageCol - 6, dm.widthPixels
    105                                     / imageCol - 6));
    106                 }
    107                 imageView.setAdjustViewBounds(true);
    108                 imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
    109             } else {
    110                 imageView = (ImageViewExt) convertView;
    111             }
    112             imageView.setImageResource(ImageSource.mThumbIds[position]);
    113  
    114             return imageView;
    115         }
    116  
    117         private Context mContext;
    118     }
    119 }
     

    加载GridView页面,如果屏幕是竖屏,则显示3列,如果是横屏,则显示4列;并且显示的图片加上灰色边框,这里在适配器GridImageAdapter的getView方法里引用了ImageViewExt类来对图片进行处理,这个类扩展自ImageView;点击其中的某一张图片,会跳转到GalleryActivity页面。

    2、ImageViewExt.java文件

     1 /**
     2  *
     3  * @author 空山不空
     4  * 扩展ImageView类,将图片加上边框,并且设置边框为灰色
     5  */
     6 public class ImageViewExt extends ImageView {
     7  //将图片加灰色的边框
     8     private int color;
     9  
    10     public ImageViewExt(Context context) {
    11         super(context);
    12        // TODO Auto-generated constructor stub
    13         color=Color.GRAY;
    14   }
    15      
    16    public ImageViewExt(Context context, AttributeSet attrs) {
    17          super(context, attrs);
    18         // TODO Auto-generated constructor stub
    19          color=Color.GRAY;
    20    }
    21  
    22      
    23     @Override
    24      protected void onDraw(Canvas canvas) {
    25          // TODO Auto-generated method stub   
    26         
    27         super.onDraw(canvas);   
    28         //画边框
    29          Rect rec=canvas.getClipBounds();
    30         rec.bottom--;
    31         rec.right--;
    32         Paint paint=new Paint();
    33         paint.setColor(color);
    34         paint.setStrokeWidth(5);
    35         paint.setStyle(Paint.Style.STROKE);
    36         canvas.drawRect(rec, paint);
    37     }
    38 }

    通过重载onDraw方法来画边框和设置边框颜色

    3、相册GalleryActivity.java

     1 /**
     2  *
     3  * @author 空山不空
     4  * Gallery图片页面,通过Intent得到GridView传过来的图片位置,加载图片,再设置适配器
     5  */
     6 public class GalleryActivity extends Activity {
     7     public int i_position = 0;
     8     private DisplayMetrics dm;
     9  
    10     @Override
    11     public void onCreate(Bundle savedInstanceState) {
    12         super.onCreate(savedInstanceState);
    13         requestWindowFeature(Window.FEATURE_NO_TITLE);
    14         setContentView(R.layout.mygallery); 
    15         dm = new DisplayMetrics();
    16         getWindowManager().getDefaultDisplay().getMetrics(dm);
    17         // 获得Gallery对象 
    18         GalleryExt  g = (GalleryExt) findViewById(R.id.ga);
    19         //通过Intent得到GridView传过来的图片位置
    20         Intent intent = getIntent();
    21         i_position = intent.getIntExtra("position", 0); 
    22         // 添加ImageAdapter给Gallery对象
    23         ImageAdapter ia=new ImageAdapter(this);    
    24         g.setAdapter(ia);
    25         g.setSelection(i_position);    
    26          
    27         //加载动画
    28         Animation an= AnimationUtils.loadAnimation(this,R.anim.scale );
    29         g.setAnimation(an);
    30  
    31     }
    32 }

     这里有三点:

    (1)、扩展Gallery组件,即GalleryExt控件,设置滑动一次只加载一张图片,并且, 如果是第一张图片时,向左滑动会提示“已到第一页”,如果是最后一张图片时,向右滑动会提示“已到第后页”

    (2)、接收GridViewActivity页面传过来的参数position,通过这个参数找到具体的图片,通过ImageAdapter适配器加载

    (3)、ImageAdapter图片适配器,用来加载图片

    4、GalleryExt.java文件

     1 /**
     2  *
     3  * @author 空山不空
     4  * 扩展Gallery组件,设置滑动一次只加载一张图片,并且,
     5  * 如果是第一张图片时,向左滑动会提示“已到第一页”
     6  * 如果是最后一张图片时,向右滑动会提示“已到第后页”
     7  */
     8 public class GalleryExt extends Gallery {
     9     boolean is_first=false;
    10     boolean is_last=false;
    11     public GalleryExt(Context context) {
    12         super(context);
    13         // TODO Auto-generated constructor stub
    14     }
    15      
    16     public GalleryExt(Context context,AttributeSet paramAttributeSet)
    17      {
    18            super(context,paramAttributeSet);
    19  
    20      }
    21  
    22     private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2)
    23        {  
    24         return e2.getX() > e1.getX();
    25        }
    26  
    27      @Override
    28     public boolean onFling(MotionEvent e1, MotionEvent e2, float distanceX,
    29                     float distanceY) {
    30  //通过重构onFling方法,使Gallery控件滑动一次只加载一张图片
    31          //获取适配器
    32          ImageAdapter ia=(ImageAdapter)this.getAdapter();
    33         //得到当前图片在图片资源中的位置
    34          int p=ia.getOwnposition();
    35          //图片的总数量
    36          int count=ia.getCount();
    37          int kEvent; 
    38           if(isScrollingLeft(e1, e2)){
    39            //Check if scrolling left 
    40               if(p==0&&is_first){
    41                   //在第一页并且再往左移动的时候,提示
    42                   Toast.makeText(this.getContext(), "已到第一页", Toast.LENGTH_SHORT).show();
    43               }else if(p==0){
    44                   //到达第一页时,把is_first设置为true
    45                   is_first=true;
    46               }else{
    47                   is_last=false;
    48               }
    49                
    50            kEvent = KeyEvent.KEYCODE_DPAD_LEFT; 
    51            }  else{
    52             //Otherwise scrolling right   
    53                if(p==count-1&&is_last){
    54                       Toast.makeText(this.getContext(), "已到最后一页", Toast.LENGTH_SHORT).show();
    55                   }else if( p==count-1){
    56                       is_last=true;
    57                   }else{
    58                       is_first=false;
    59                   }
    60                    
    61             kEvent = KeyEvent.KEYCODE_DPAD_RIGHT;  
    62             } 
    63           onKeyDown(kEvent, null); 
    64           return true; 
    65     }
     

    5、ImageAdapter.java文件

     1 /**
     2  *
     3  * @author 空山不空
     4  *  图片适配器,用来加载图片
     5  */
     6 public class ImageAdapter extends BaseAdapter {
     7 //图片适配器
     8     // 定义Context
     9     private int ownposition;
    10       
    11  
    12     public int getOwnposition() {
    13         return ownposition;
    14     }
    15  
    16     public void setOwnposition(int ownposition) {
    17         this.ownposition = ownposition;
    18     }
    19  
    20     private Context mContext;
    21  
    22     // 定义整型数组 即图片源
    23  
    24     // 声明 ImageAdapter
    25     public ImageAdapter(Context c) {
    26         mContext = c;
    27     }
    28  
    29     // 获取图片的个数
    30     public int getCount() {
    31         return ImageSource.mThumbIds.length;
    32     }
    33  
    34     // 获取图片在库中的位置
    35     public Object getItem(int position) {
    36         ownposition=position;
    37         return position;
    38     }
    39  
    40     // 获取图片ID
    41     public long getItemId(int position) {
    42         ownposition=position;
    43         return position;
    44     }
    45  
    46     public View getView(int position, View convertView, ViewGroup parent) {
    47  
    48           
    49         ownposition=position;
    50         ImageView imageview = new ImageView(mContext);
    51         imageview.setBackgroundColor(0xFF000000);
    52         imageview.setScaleType(ImageView.ScaleType.FIT_CENTER);
    53         imageview.setLayoutParams(new GalleryExt.LayoutParams(
    54                 LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
    55  
    56         imageview.setImageResource(ImageSource.mThumbIds[position]);
    57         // imageview.setAdjustViewBounds(true);
    58         // imageview.setLayoutParams(new GridView.LayoutParams(320, 480));
    59         // imageview.setScaleType(ImageView.ScaleType.CENTER_INSIDE);
    60         return imageview;
    61     }
    62 }
     

    6、配置文件

    (1)AndroidManifest.xml :

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
          package="com.ajie"
          android:versionCode="1"
          android:versionName="1.0">
        <application android:icon="@drawable/icon"  android:label="@string/app_name">
        <activity android:name=".GalleryActivity"  android:label="@string/title"  /> 
        <activity android:name=".GridViewActivity"  android:label="@string/app_name"   android:configChanges="orientation|keyboardHidden" >      
              <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter> 
        </activity> 
        </application>
    </manifest>
     

    (2)mygridview.xml,即GridView页面

     1 <?xml version="1.0" encoding="utf-8"?>
     2   
     3  
     4 <GridView xmlns:android="http://schemas.android.com/apk/res/android"
     5     android:id="@+id/myGrid"
     6     android:layout_width="fill_parent"
     7     android:layout_height="fill_parent"
     8     android:verticalSpacing="6dp" 
     9     android:numColumns="3"   
    10     android:paddingTop="5dp"
    11     android:stretchMode="columnWidth" 
    12     android:gravity="fill_vertical|fill_horizontal"
    13     />
     

    (3)mygallery.xml,加载图片页面

     1 <?xml version="1.0" encoding="utf-8"?>
     2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
     3     android:orientation="horizontal" android:layout_width="match_parent"
     4     android:layout_height="match_parent" android:gravity="center"
     5     android:padding="10dip">
     6     <RelativeLayout android:layout_width="wrap_content"
     7         android:layout_height="wrap_content" android:padding="2dip"
     8         android:background="#000000">
     9  
    10         <com.ajie.GalleryExt android:id="@+id/ga"
    11             android:layout_width="fill_parent" android:layout_height="fill_parent"
    12             android:spacing="16dp" />
    13     </RelativeLayout>
    14 </LinearLayout>
     

    Demo下载地址:<a href="http://files.cnblogs.com/fbsk/gridGalleryDemo.zip"> gridGalleryDemo.zip下载</a>

    转自:http://www.cnblogs.com/fbsk/archive/2011/10/10/2205776.html

  • 相关阅读:
    使用图形界面调试arm程序: insight + gdb
    skyeye相关命令简介
    /bin/sh: can
    安装skyeye1.3.3 过程中可能遇到的问题
    linux下ARM汇编程序的调试
    ARM标准汇编与GNU汇编
    从ARMASM汇编到GNU ARM ASM汇编
    How much faster is assembly language?
    A number of problems from coded in ARM assembly language Problems
    An exploration of ARM assembly language
  • 原文地址:https://www.cnblogs.com/Sharley/p/5580714.html
Copyright © 2011-2022 走看看