`
huangbq
  • 浏览: 30635 次
  • 性别: 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  
不错,不过有个截图就好了

相关推荐

    安卓Android源码——Gallery相册浏览.zip

    本资源“安卓Android源码——Gallery相册浏览.zip”提供了一个关于如何实现一个自定义相册浏览功能的示例,即GalleryDemo。这个项目可以帮助开发者了解Android系统的图片加载、滚动效果以及UI设计等方面的知识。 1....

    Gallery——Gallery

    `Gallery`控件的设计初衷是为了提供一个直观且互动性强的界面,让用户能够轻松地在多个项目间进行切换,常被用作相册应用的核心组件。 一、Gallery的基本使用 `Gallery`控件继承自`AbsSpinner`,并扩展了水平方向...

    安卓Android源码——CustomGalleryLikeiPhone(3D相册).rar

    本项目"安卓Android源码——CustomGalleryLikeiPhone(3D相册).rar"就是一个实例,它旨在模仿苹果iPhone上的3D相册效果,为用户带来更加生动、交互性强的图片浏览体验。下面我们将深入探讨这个项目的相关知识点。 ...

    安卓Android源码——CustomGalleryLikeiPhone(3D相册).zip

    通常,Gallery控件会结合Adapter来展示数据。这里的CustomGallery会使用一个自定义的Adapter,比如ArrayAdapter或者CursorAdapter,将图片数据(可能是从资源文件、网络或数据库中获取)绑定到每个Item上,使得每个...

    Android 高性能相册滑动拖动控件

    在Android开发中,创建一个高性能的相册滑动拖动控件是许多应用必不可少的功能,尤其是在处理大量图片时。这个控件需要具有流畅的用户体验、高效的内存管理以及良好的可定制性。下面我们将深入探讨实现此类控件的...

    安卓Andriod源码——GalleryDemo.zip

    在Android应用开发中,Gallery组件是一个非常实用的控件,常用于图片浏览、选项选择等场景。本文将深入探讨名为"GalleryDemo"的示例代码,帮助开发者更好地理解和运用这个组件。 1. **Gallery组件介绍** Gallery是...

    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章 用户人机...

    Android高级应用源码-GalleryDemo.zip

    通过对GalleryDemo源码的深入研究,开发者不仅可以掌握Gallery控件的使用,还能了解到Android图像处理、性能优化、手势识别等多个方面的知识,这对于提升Android应用的用户体验和开发能力具有极大的帮助。

    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章 用户人机...

    CustomGalleryLikeiPhone(3D相册).zip

    《安卓3D相册实现详解——基于"CustomGalleryLikeiPhone(3D相册).zip"的实践指导》 在移动开发领域,Android系统以其开放性和丰富的应用生态,吸引了无数开发者投身其中。对于初学者或者正在进行毕业设计或课程...

Global site tag (gtag.js) - Google Analytics