24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1259  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085600材料与化工调剂 5+3 孜孜不倦2002 2026-04-19 6/300 2026-04-20 21:25 by babero
[考研] 320求调剂 +6 深郊akm 2026-04-17 6/300 2026-04-20 18:57 by fs26jie
[论文投稿] 期刊推荐 +3 材料研究生 2026-04-15 5/250 2026-04-20 16:02 by 豆豆7758
[教师之家] 又一批高校组建人工智能学院 师资行吗 不是骗人吗 +4 yexuqing 2026-04-19 4/200 2026-04-20 14:47 by brantleo
[考研] 297,工科调剂?河南农业大学本科 +15 河南农业大学-能 2026-04-14 15/750 2026-04-20 12:39 by Equinoxhua
[考研] 337求调剂 +3 jyz04 2026-04-18 3/150 2026-04-20 12:24 by 研可安
[考博] 申博 +3 Xyyx. 2026-04-18 3/150 2026-04-20 10:44 by YuY66
[考研] 求计算机方向调剂 +3 Toffee2 2026-04-16 6/300 2026-04-19 22:37 by ll叶
[考研] 291求调剂 +11 关忆北. 2026-04-14 11/550 2026-04-19 17:16 by 中豫男
[考研] 304求调剂 +8 castLight 2026-04-16 8/400 2026-04-19 17:14 by 中豫男
[考研] 291求调剂 +12 关忆北. 2026-04-14 13/650 2026-04-19 16:50 by 中豫男
[考研] 085404 22408 309分求调剂 +10 lzmk 2026-04-14 11/550 2026-04-19 16:42 by 中豫男
[考研] 求调剂 +6 苦命人。。。 2026-04-18 7/350 2026-04-19 16:27 by 中豫男
[考研] 307中医考研调剂 +9 于以采蘩 2026-04-14 9/450 2026-04-19 08:41 by 烟雨流涯
[考研] 0854求调剂 +23 门路摸摸 2026-04-15 27/1350 2026-04-19 01:59 by 烟雨流涯
[考研] 260求调剂 +4 Zyt1314520.. 2026-04-17 5/250 2026-04-18 08:28 by babysonlkd
[考研] 一志愿华中农业071010,320求调剂 +17 困困困困坤坤 2026-04-14 19/950 2026-04-17 20:08 by 关一盏灯cd
[有机交流] 二苯甲酮酸类衍生物 50+3 小白爱主人 2026-04-17 6/300 2026-04-17 18:47 by kf2781974
[考研] 295分求调剂 +5 ?要上岸? 2026-04-17 5/250 2026-04-17 16:51 by fenglj492
[考研] 药学求调剂 +14 喽哈加油 2026-04-14 16/800 2026-04-16 10:15 by beilsong20
信息提示
请填处理意见