`
huangbq
  • 浏览: 30261 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Gallery控件初体验——简单的相册

阅读更多

 

初学android,学着做了一个小例子,例子非常简单,就是用Gallery实现一个简单的相册,由于我是初学者,所以我遇到的问题可能也是初学者也会遇到的问题,在完成这个小例子过程中遇到了很多意想不到的问题,最后借助网络都解决了,现在把我做的这个小例子拿出分享给各位初学者!我做了尽可能详细的注释,我想一定会对初学者有所帮助!由于初学android,例子也是超级简单,路过的各位大侠请勿见笑!

Gallery:即图片浏览控件

layout部分:

 

<?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" >

 

   <Gallery android:id="@+id/gallery"

            android:layout_width="fill_parent"

            android:layout_height="wrap_content"

            >

   </Gallery>

   <ImageView android:id="@+id/img_show"

              android:layout_width="wrap_content"

              android:layout_height="wrap_content">

  </ImageView>     

</LinearLayout>

 

代码部分:

主类部分代码:

GalleryActivity类

 

package com.google.android.test;

 

 

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import android.widget.AdapterView;

import android.widget.Gallery;

import android.widget.ImageView;

import android.widget.Toast;

 

public class GalleryActivity extends Activity {

/*定义要使用的对象*/

private Gallery gallery;

private ImageView imageView;

private ImageAdapter imageadapter;

@Override

public void onCreate(Bundle savedInstanceState){

super.onCreate(savedInstanceState);

setContentView(R.layout.gallery);

/* 通过findViewById 取得 资源对象*/

gallery=(Gallery)this.findViewById(R.id.gallery);

imageView=(ImageView)findViewById(R.id.img_show);

/*给Gallery设置适配器 把GalleryActivity类传入参数*/

imageadapter=new ImageAdapter(this);

gallery.setAdapter(imageadapter);

/*设置Gallery的点击事件监听器*/

gallery.setOnItemClickListener(new Gallery.OnItemClickListener(){ 

@Override  

public void onItemClick(AdapterView<?> parent, View v, int position, long id) { 

// TODO Auto-generated method stub

/*设置大图片*/

imageView.setBackgroundResource(imageadapter.mImageIds[position]);

/*显示该图片是几号*/

Toast.makeText(GalleryActivity.this,"你选择了"+(position)+"号图片",Toast.LENGTH_SHORT).show();

}

});

}

 

}


 

ImageAdapter 类

 

package com.google.android.test;

 

import android.content.Context;

import android.util.Log;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.Gallery;

import android.widget.ImageView;

 

public class ImageAdapter extends BaseAdapter{

/*变量声明*/

   private Context mContext;//上下文

   /* 构建一Integer array 并取得预加载Drawable 的图片id */

   public Integer[] mImageIds={

R.drawable.img1,  

R.drawable.img2,

R.drawable.img3,

R.drawable.img4,

R.drawable.img5

   };

   /*自定义的构造方法*/

   public ImageAdapter(Context c){

// TODO Auto-generated constructor stub

  this.mContext=c;

   }

   @Override

   /* 重写的方法getCount,返回图片数目 */

   public int getCount(){

// TODO Auto-generated constructor stub

  return mImageIds.length;//获取图片的个数 

   }

   @Override

   /* 重写的方法getItemId,返回图像的数组id */

   public Object getItem(int position){

// TODO Auto-generated constructor stub

  return position;//获取图片在库中的位置

   }

   @Override

   public long getItemId(int position){

// TODO Auto-generated constructor stub

  return position;//获取图片在库中的位置  

   }

   @Override

   /* 重写的方法getView,返回一View 对象 */

   public View getView(int position,View convertView,ViewGroup parent){

// TODO Auto-generated constructor stub

  Log.i("Tag", position+"");

  /* 产生ImageView 对象 */

  ImageView imageView=new ImageView(mContext);

  /* 设置图片给imageView 对象 */

  imageView.setImageResource(mImageIds[position]);

  /* 重新设置Layout 的宽高 */

  imageView.setLayoutParams(new Gallery.LayoutParams(128,128));

  /* 重新设置图片的宽高 */

  imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);

  /* 返回imageView 对象 */

  return imageView;

   }

}

 

 

分享到:
评论
6 楼 huangbq 2011-08-04  
y185130162 写道
呀  发这么多。。。不好意思了   你看看那个完整的。。是4楼的那个 ,,可以给我解决下吗


这个一个缩放函数,你改造一下试试看!
    /**
     * 缩放
     */ 
    private void scale(double  scale_width, double scale_height) { 
         
        //这种方法,有点不好是:如果图片大小超出屏幕会报错。 
        if((scale_width > 1 && scaleWidth * primaryWidth >= getWindowManager().getDefaultDisplay().getWidth()) 
                || (scale_width > 1 && scale_height * primaryHeight >= getWindowManager().getDefaultDisplay().getHeight())){ 
            bt_bigger.setEnabled(false); 
        }else { 
            bt_bigger.setEnabled(true); 
        } 
             
         
         
        scaleWidth = scaleWidth * scale_width;  //缩放到原来的*倍 
        scaleHeight = scaleHeight * scale_height; 
         
        Matrix matrix = new Matrix();   //矩阵,用于图片比例缩放 
        matrix.postScale((float)scaleWidth, (float)scaleHeight);    //设置高宽比例(三维矩阵) 
         
        //缩放后的BitMap 
        Bitmap newBmp = Bitmap.createBitmap(bmp, 0, 0, primaryWidth, primaryHeight, matrix, true);  
         
        //重新设置BitMap 
        imageView.setImageBitmap(newBmp); 
     
    }
5 楼 y185130162 2011-07-25  
呀  发这么多。。。不好意思了   你看看那个完整的。。是4楼的那个 ,,可以给我解决下吗
4 楼 y185130162 2011-07-25  
楼主 你好 我现在想显示网络上图片 这是三张网络上的图片/.

[/list]

private String[] myImageURL = new String[] {
"http://static.panoramio.com/photos/iw-thumbnail/25454991.jpg",
"http://t0.gstatic.com/images?q=tbn:ANd9GcQ0TG9i0tdvE2Z5b2xuaW8jJ1u0rnYoN4ovhDxJG3BYH-pms5Y",
"http://static.panoramio.com/photos/iw-thumbnail/25454970.jpg" };

//这是getview方法
public View getView(int position, View convertView, ViewGroup parent) {
imageView = new ImageView(mContext);

try {

URL aryURI = new URL(myImageURL[position]);
URLConnection conn = aryURI.openConnection();

InputStream is = conn.getInputStream();
    bm = BitmapFactory.decodeStream(is);
is.close();

imageView.setImageBitmap(bm);
conn.connect();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
// 设置布局参数
imageView.setLayoutParams(new Gallery.LayoutParams(120, 120));
// 设置风格,此风格的配置是在xml中
imageView.setBackgroundResource(mGalleryItemBackground);
return imageView;
}

我想是在选中Gallery中某个图像时,在ImageSwitcher组件中放大显示该图像
请问
public void onItemSelected(AdapterView<?> parent, View view, int position,
long id){
在这个方法里该怎么样 让imageviewSwitcher 放大图像呢。。
}
3 楼 y185130162 2011-07-25  
楼主 你好 我现在想显示网络上图片 这是三张网络上的图片/.

[/list]

private String[] myImageURL = new String[] {
"http://static.panoramio.com/photos/iw-thumbnail/25454991.jpg",
"http://t0.gstatic.com/images?q=tbn:ANd9GcQ0TG9i0tdvE2Z5b2xuaW8jJ1u0rnYoN4ovhDxJG3BYH-pms5Y",
"http://static.panoramio.com/photos/iw-thumbnail/25454970.jpg" };

//这是getview方法
public View getView(int position, View convertView, ViewGroup parent) {
imageView = new ImageView(mContext);

try {

URL aryURI = new URL(myImageURL[position]);
URLConnection conn = aryURI.openConnection();

InputStream is = conn.getInputStream();
    bm = BitmapFactory.decodeStream(is);
is.close();

imageView.setImageBitmap(bm);
conn.connect();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
// 设置布局参数
imageView.setLayoutParams(new Gallery.LayoutParams(120, 120));
// 设置风格,此风格的配置是在xml中
imageView.setBackgroundResource(mGalleryItemBackground);
return imageView;
}

我想是在选中Gallery中某个图像时,在ImageSwitcher组件中放大显示该图像
请问
public void onItemSelected(AdapterView<?> parent, View view, int position,
long id){

}
2 楼 y185130162 2011-07-25  
楼主 你好 我现在想显示网络上图片 这是三张网络上的图片/.

[/list]

private String[] myImageURL = new String[] {
"http://static.panoramio.com/photos/iw-thumbnail/25454991.jpg",
"http://t0.gstatic.com/images?q=tbn:ANd9GcQ0TG9i0tdvE2Z5b2xuaW8jJ1u0rnYoN4ovhDxJG3BYH-pms5Y",
"http://static.panoramio.com/photos/iw-thumbnail/25454970.jpg" };
1 楼 pin5icobra 2010-06-12  
不错,不过有个截图就好了

相关推荐

    Google Android SDK开发范例大全(PDF高清完整版3)(4-3)

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(PDF完整版4)(4-4)

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(PDF高清完整版1)(4-1)

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全的目录

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google+Android+SDK开发范例大全

    1.1 红透半边天的Android 1.2 本书目的及涵盖范例范围 1.3 如何阅读本书 1.4 使用本书范例 1.5 参考网站 第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!...

    Google Android SDK开发范例大全(完整版附部分源码).pdf

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 ...

    Google Android sdk 开发范例大全 部分章节代码

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK 开发范例大全01

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK 开发范例大全02

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(完整版)

    第2章 Android初体验 2.1 安装AndroidSDK与ADTplug-in 2.2 建立第一个Android项目(HelloAndroid!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    google android sdk开发范例大全 第二版 PDF 光盘代码

    第2章 Android初体验   2.1 安装Android SDK与ADT/DDMS   2.2 创建第一个Android项目(Hello Android!)   2.3 Android应用程序架构——从此开始   2.4 可视化的界面开发工具   2.5 部署应用程序...

    Google Android SDK开发范例大全(第3版) 1/5

    第2章 Android初体验 2.1 安装Android SDK与ADT/DDMS 2.2 创建第一个Android项目(Hello Android!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(第3版) 4/5

    第2章 Android初体验 2.1 安装Android SDK与ADT/DDMS 2.2 创建第一个Android项目(Hello Android!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(第3版) 3/5

    第2章 Android初体验 2.1 安装Android SDK与ADT/DDMS 2.2 创建第一个Android项目(Hello Android!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(第3版) 5/5

    第2章 Android初体验 2.1 安装Android SDK与ADT/DDMS 2.2 创建第一个Android项目(Hello Android!) 2.3 Android应用程序架构——从此开始 2.4 可视化的界面开发工具 2.5 部署应用程序到Android手机 第3章 用户人机...

    Google Android SDK开发范例大全(第3版)part2

     第2章 Android初体验  2.1 安装Android SDK与ADT/DDMS  2.2 创建第一个Android项目(Hello Android!)  2.3 Android应用程序架构——从此开始  2.4 可视化的界面开发工具  2.5 部署应用程序到Android手机 ...

    《Google Android SDK开发范例大全(第3版)》.pdf

    第2章 android初体验 7 2.1 安装android sdk与adt/ddms 8 2.2 创建第一个android项目(hello android!) 11 2.3 android应用程序架构——从此开始 15 2.4 可视化的界面开发工具 18 2.5 部署应用程序到...

Global site tag (gtag.js) - Google Analytics