Android使用ViewPager加载图片和轮播视频
程序员文章站
2023-12-11 11:24:10
作为android基础组件之一,大家对viewpager已经很熟悉了,网上也有很多使用viewpager来加载图片的案例。但是像微信那样点击图片,可以轮播显示图片和视频的例...
作为android基础组件之一,大家对viewpager已经很熟悉了,网上也有很多使用viewpager来加载图片的案例。但是像微信那样点击图片,可以轮播显示图片和视频的例子却没找到。正巧项目中有需求,可以就花时间写了下,现在给一下核心代码,希望对有此需求的同学们起一个抛砖引玉的作用。话不多说了,上代码:
以下是initdata的代码
public void initdata() { //把聊天界面的图片和视频找出来,并加到数组中,并在 //并根据传进来的position来找到视频或图片在数组中的位置 for (int i = 0; i < msgcount; i++) { msg1 msg1 = fridenmessages.messagelist.get(i); if (msg1.getmsg().startswith(chatutil.tag_image) || msg1.getmsg().startswith(chatutil.tag_video)) { imageurl.add(msg1.getmsg()); //查看消息postion对应的图片位置 if (position == i) { position = imageurl.size() - 1; log.i("tag", "position=" + position); } } } log.i("tag", "position=" + position); //把要用到的view加到viewlist中 for (int i = 0; i < imageurl.size(); i++) { if (imageurl.get(i).startswith(chatutil.tag_image)) { photoview photoview = new photoview(context); viewlist.add(photoview); } else if (imageurl.get(i).startswith(chatutil.tag_video)) { view view1 = layoutinflater.from(context).inflate(r.layout.activity_video_player, null); surfacevideoview videoview = (surfacevideoview) view1.findviewbyid(r.id.videoview); int screenwidth = getscreenwidth((activity) context); int videohight = (int) (screenwidth / (mediarecorderbase.small_video_width / (mediarecorderbase.small_video_height * 1.0f))); // int videohight = (int) (screenwidth)*4/3; videoview.getlayoutparams().height = videohight; videoview.requestlayout(); view playstatus = view1.findviewbyid(r.id.play_status); view loading = view1.findviewbyid(r.id.loading); viewlist.add(view1); } } adapter = new myadapter(); viewpager.setadapter(adapter); if (position != -1) { viewpager.setcurrentitem(position); } } ``` public void initevent() { //给viewpager设置监听 viewpager.setonpagechangelistener(new viewpager.onpagechangelistener() { @override public void onpageselected(int arg0) { int childcount = viewpager.getchildcount();//viewpager得到页面的数量 //如果不是在原页面,让原来页面的视频停止播放 if(position != arg0){ position=arg0; stopvideo(); } // 遍历当前所有加载过的photoview,恢复所有图片的默认状态 for (int i = 0; i < childcount; i++) { view childat = viewpager.getchildat(i); try { if (childat != null && childat instanceof photoview) { photoview photoview = (photoview) childat; photoview.setonphototaplistener(new photoviewattacher.onphototaplistener() { @override public void onphototap(view view, float x, float y) { finish(); } @override public void onoutsidephototap() { } }); } } catch (exception e) { e.printstacktrace(); } } if (imageurl.get(position).startswith(chatutil.tag_video)) { string body = chatapplication.dbhelper.getvideosdpath(imageurl.get(position)); string url[] = imageurl.get(position).substring(chatutil.tag_video.length()).split("&&"); view childat = viewlist.get(arg0); surfacevideoview videoview = (surfacevideoview) childat.findviewbyid(r.id.videoview); mvideoview = videoview; mplayerstatus = childat.findviewbyid(r.id.play_status); mloading = childat.findviewbyid(r.id.loading); log.i("tag", "videourl=" + body); setvideourl(body, url); //延迟50ms,让播放器播放视频时,让它暂停 handler handler = new handler(); handler.postdelayed(new runnable() { @override public void run() { stopvideo(); } }, 50); } } @override public void onpagescrolled(int arg0, float arg1, int arg2) { // todo auto-generated method stub } @override public void onpagescrollstatechanged(int arg0) { // todo auto-generated method stub } }); } public class myadapter extends pageradapter { @override public int getcount() { return imageurl.size(); } @override public view instantiateitem(viewgroup container, int pos) { log.i("tag", "pos=" + pos); if (imageurl.get(pos).startswith(chatutil.tag_image)) { photoview photoview = (photoview) viewlist.get(pos); container.addview(photoview, viewgroup.layoutparams.match_parent, viewgroup.layoutparams.match_parent); string body[] = imageurl.get(pos).substring(chatutil.tag_image.length()).split("&&"); log.i("tag", "<image>=" + body[0]); imageloader.getinstance().displayimage(body[0], photoview); photoview.setscaletype(imageview.scaletype.fit_center);//设置图片显示为充满全屏 photoview.setonphototaplistener(new photoviewattacher.onphototaplistener() { @override public void onphototap(view view, float x, float y) { finish(); } @override public void onoutsidephototap() { } }); // photoview.setonlongclicklistener(longclicklistener); } else if (imageurl.get(pos).startswith(chatutil.tag_video)) { view view1 = viewlist.get(pos); surfacevideoview videoview = (surfacevideoview) view1.findviewbyid(r.id.videoview); int screenwidth = getscreenwidth((activity) context); int videohight = (int) (screenwidth / (mediarecorderbase.small_video_width / (mediarecorderbase.small_video_height * 1.0f))); // int videohight = (int) (screenwidth)*4/3; videoview.getlayoutparams().height = videohight; videoview.requestlayout(); view playerstatus = view1.findviewbyid(r.id.play_status); view loading = view1.findviewbyid(r.id.loading); videoview.setonpreparedlistener(showbigpictureactivity.this); videoview.setonplaystatelistener(showbigpictureactivity.this); videoview.setonerrorlistener(showbigpictureactivity.this); videoview.setonclicklistener(showbigpictureactivity.this); videoview.setoninfolistener(showbigpictureactivity.this); videoview.setoncompletionlistener(showbigpictureactivity.this); container.addview(view1, viewgroup.layoutparams.match_parent, viewgroup.layoutparams.match_parent); string body = chatapplication.dbhelper.getvideosdpath(imageurl.get(pos)); string url[] = imageurl.get(pos).substring(chatutil.tag_video.length()).split("&&"); //找到是点击聊天界面哪个视频进来的,将局部成员,付给类成员 if(pos==position) { mvideoview = videoview; mplayerstatus=playerstatus; mloading=loading; setvideourl(body,url); } } return viewlist.get(pos); } @override public void destroyitem(viewgroup container, int position, object object) { container.removeview((view) object); } @override public boolean isviewfromobject(view view, object object) { return view == object; } } 以下是控制视频播放的接口: public void oncompletion(mediaplayer mp) { onstatechanged(false); } @override public boolean onerror(mediaplayer mp, int what, int extra) { return false; } @override public boolean oninfo(mediaplayer mp, int what, int extra) { switch (what) { case mediaplayer.media_info_bad_interleaving: // 音频和视频数据不正确 configutil.showshort(context, "视频数据不正确!"); break; case mediaplayer.media_info_buffering_start: if (!isfinishing()) mvideoview.pause(); break; case mediaplayer.media_info_buffering_end: if (!isfinishing()) mvideoview.start(); break; case mediaplayer.media_info_video_rendering_start: if (deviceutils.hasjellybean()) { mvideoview.setbackground(null); } else { mvideoview.setbackgrounddrawable(null); } break; } return false; } @override public void onstatechanged(boolean isplaying) { mplayerstatus.setvisibility(isplaying ? view.gone : view.visible); } @override public void onprepared(mediaplayer mp) { mvideoview.setvolume(surfacevideoview.getsystemvolumn(this)); mvideoview.start(); mloading.setvisibility(view.gone); }
我觉得轮播视频的难点在于viewpager只能播放一个视频,而每个viewitem都有继承自surfaceview的surfacevideoview控件, 我让原先页面的surfaceviedeoview停止播放,并把新页面的surfacevideoview付给mvideoview,然后就可以对选中页面的视频进行控制了。
下面来张效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。