24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1083  |  回复: 7

qqhegg

荣誉版主 (文坛精英)

珊瑚小美-----小元家的九妹

优秀版主优秀版主

[交流] android 学习笔记之-------类似幻灯片的图片查看器已有3人参与

今天突发奇想,还多亏毛猴亲每天一个奇怪的点子,所以就想或许可以做个幻灯片,于是想着幻灯片可不可以像C语言那样,我用计时器的方式,每隔一秒就换一次图片,开线程来处理。后来在网上看到有用gallery+imageSwitcher做的,便尝试了一下。
先来分享一下简单的图片查看器:
ImageSwitcher:由FrameLayout衍生出来的,和ImageView差不多,但是但是它能设置动画效果,一会代码啊便会看到。
一般使用ImageSwitcher一般要为他设置一个ImageSwitcher.ViewFactory来实现ImageSwitcher。ViewFactory需要实现一个makeView()方法,返回一个ImageView,而ImageSwitcher来显示这个ImageView。
Gallery是个画廊视图,显示水平列表选择框,允许用户拖动查看图片。
程序就是再点击gallery而让ImageSwitcher显示出所点击的那种图片。
下面贴代码:
布局文件:
CODE:
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    >
   
            android:layout_width="320px"
        android:layout_height="480px"
        
    />
   
            android:background="#55000000"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
         android:gravity="center"
        android:spacing="0dp"
    />

我用了linearLayout
贴代码:
CODE:
public class AbActivity extends Activity  {
    /** Called when the activity is first created. */
        private Gallery gallery;
        private ImageSwitcher switcher;
        //照片是我自己命名的,大家可以修改,放到drawable下面就好了
        private Integer[] imageIds = {R.drawable.heart,
                        R.drawable.lp,R.drawable.rp,
                        R.drawable.lover,
                        };
        private Integer[] mThumbIds = { R.drawable.heart,
                        R.drawable.lp,R.drawable.rp,
                        R.drawable.lover,
                        };
       
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
       gallery=(Gallery)findViewById(R.id.gallery);
       switcher=(ImageSwitcher)findViewById(R.id.switcher);
//ImageSwicher的ViewFactory的实现
       switcher.setFactory(new ViewFactory(){

                @Override
                public View makeView() {
                        // TODO Auto-generated method stub
                        ImageView image=new ImageView(AbActivity.this);
                        image.setScaleType(ImageView.ScaleType.FIT_CENTER);
                        image.setBackgroundColor(0xFF000000);
                        image.setLayoutParams(new ImageSwitcher.LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT));
                        return image;
                }});
     //设置动画效果
     switcher.setInAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_in));
     switcher.setOutAnimation(AnimationUtils.loadAnimation(this, android.R.anim.fade_out));
   //Gallery实现之前必须要实现Adapter,因为它是一个列表框
     BaseAdapter adapter=new BaseAdapter(){

                @Override
                public int getCount() {
                        // TODO Auto-generated method stub
                        return imageIds.length;
                }

                @Override
                public Object getItem(int arg0) {
                        // TODO Auto-generated method stub
                        return arg0;
                }

                @Override
                public long getItemId(int arg0) {
                        // TODO Auto-generated method stub
                        return arg0;
                }

                @Override
                public View getView(int arg0, View arg1, ViewGroup arg2) {
                        // TODO Auto-generated method stub
                        ImageView image=new ImageView(AbActivity.this);
                        image.setImageResource(mThumbIds[arg0%imageIds.length]);
                        image.setScaleType(ImageView.ScaleType.FIT_CENTER);
                        image.setLayoutParams(new Gallery.LayoutParams(75,100 ));
                        TypedArray typeArray=obtainStyledAttributes(R.styleable.Gallery);
                        image.setBackgroundResource(typeArray.getResourceId(R.styleable.Gallery_android_galleryItemBackground, 0));
                        return image;
                }};
                gallery.setAdapter(adapter);
                gallery.setOnItemClickListener(new OnItemClickListener(){
//单击事件显示图片
                        @Override
                        public void onItemClick(AdapterView arg0, View arg1, int arg2,
                                        long arg3) {
                                // TODO Auto-generated method stub
                        switcher.setImageResource(imageIds[arg2%imageIds.length]);
                               
                        }});
               
       }

}

下面重点:
必须要注册,我刚开始运行一直报错,提示不能运行2个View
后来加了一句
   
在htc G12上成功运行,不贴图了,大家自己试一下,找一些自己喜欢的照片、

[ Last edited by qqhegg on 2012-4-20 at 22:42 ]
回复此楼

» 收录本帖的淘帖专辑推荐

经典资源帖 android学习笔记 android资料

» 本帖已获得的红花(最新10朵)

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

每天都是新的一天,每天上帝都会给你不同的惊喜
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
送鲜花一朵
2楼2012-04-20 22:38:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

qqhegg

荣誉版主 (文坛精英)

引用回帖:
2楼: Originally posted by leimiao_hit at 2012-04-20 22:38:07:

3楼2012-04-20 22:40:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
引用回帖:
3楼: Originally posted by qqhegg at 2012-04-20 22:40:45:

4楼2012-04-21 09:37:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zzahkj

木虫 (著名写手)

非常感谢楼主共享
不要迷恋哥,哥只是一个过客!
5楼2012-04-21 10:45:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

qqhegg

荣誉版主 (文坛精英)

引用回帖:
5楼: Originally posted by zzahkj at 2012-04-21 10:45:53:
非常感谢楼主共享

6楼2012-04-21 10:48:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

7楼2012-04-21 18:39:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
8楼2012-04-22 23:30:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 qqhegg 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见