studio无限轮播
- <?xml version="1.0" encoding="utf-8"?>
- <RelativeLayout
- xmlns:android="http://schemas.android.com/apk/res/android"
- xmlns:app="http://schemas.android.com/apk/res-auto"
- xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
- android:layout_height="match_parent" tools:context="com.example.b_week3.MainActivity">
- <android.support.v4.view.ViewPager
- android:layout_width="match_parent"
- android:layout_height="100dp"
- android:id="@+id/pager"></android.support.v4.view.ViewPager>
- <LinearLayout
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:id="@+id/ll"
- android:orientation="vertical">
- <RadioGroup
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:id="@+id/rg"
- android:orientation="horizontal"
- android:gravity="center"
- android:layout_marginTop="50dp">
- <RadioButton
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:id="@+id/rb1"
- android:checked="true"/>
- <RadioButton
- android:id="@+id/rb2"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content" />
- <RadioButton
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:id="@+id/rb3"/>
- </RadioGroup>
- </LinearLayout>
- <com.limxing.xlistview.view.XListView
- android:layout_below="@+id/pager"
- android:id="@+id/xlv"
- android:layout_width="match_parent"
- android:layout_height="match_parent"></com.limxing.xlistview.view.XListView>
- </RelativeLayout>
- public class MainActivity extends AppCompatActivity implements XListView.IXListViewListener{
- private boolean flag;
- private ViewPager pager;
- private RadioGroup rg;
- private int con=;
- private int page=;
- private List<String > imagelist=new ArrayList<String>();
- private Handler handler=new Handler(){
- @Override
- public void handleMessage(Message msg) {
- int what=msg.what;
- pager.setCurrentItem(what);
- }
- };
- private XListView xlv;
- private List<Bean.ResultBean.DataBean> list;
- private MyBaseadapter adapter;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- pager = (ViewPager) findViewById(R.id.pager);
- rg = (RadioGroup) findViewById(R.id.rg);
- imagelist.add("http://cdn.duitang.com/uploads/blog/201308/18/20130818150526_Ru2Bk.thumb.600_0.png");
- imagelist.add("http://www.bkill.com/u/info_img/2012-09/02/2012083116140522302.jpg");
- imagelist.add("http://www.it165.net/uploadfile/2011/1218/20111218070928328.jpg");
- pager.setAdapter(new My());
- jian();
- new Thread(){
- @Override
- public void run() {
- while(true) {
- try {
- Thread.sleep();
- con++;
- handler.sendEmptyMessage(con);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
- }.start();
- xlv = (XListView) findViewById(R.id.xlv);
- xlv.setPullLoadEnable(true);
- xlv.setXListViewListener(this);
- aa();
- }
- public void aa(){
- jiexi("http://apis.juhe.cn/cook/query?key=900eb2e99f3c7b21f3914aefa914a327&menu=%E8%A5%BF%E7%BA%A2%E6%9F%BF&rn=10&pn="+page+"");
- }
- public void jiexi(String path){
- new AsyncTask<String ,Void,String>(){
- @Override
- protected void onPostExecute(String s) {
- if (s!=null){
- Gson gson=new Gson();
- Bean bean = gson.fromJson(s, Bean.class);
- List<Bean.ResultBean.DataBean> list = bean.getResult().getData();
- if (adapter==null){
- adapter= new MyBaseadapter(MainActivity.this,list);
- xlv.setAdapter(adapter);
- }else{
- adapter.sss(list,flag);
- }
- }
- }
- @Override
- protected String doInBackground(String... params) {
- try {
- URL url=new URL(params[]);
- HttpURLConnection connection = (HttpURLConnection) url.openConnection();
- connection.setRequestMethod("GET");
- connection.setReadTimeout();
- connection.setConnectTimeout();
- int code = connection.getResponseCode();
- if (code==){
- InputStream is = connection.getInputStream();
- return info.readFromNetWork(is);
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- }.execute(path);
- }
- @Override
- public void onRefresh() {
- flag=false;
- ++page;
- aa();
- xlv.stopRefresh(true);
- }
- @Override
- public void onLoadMore() {
- flag=true;
- ++page;
- aa();
- xlv.stopLoadMore();
- }
- class My extends PagerAdapter{
- @Override
- public int getCount() {
- return Integer.MAX_VALUE;
- }
- @Override
- public boolean isViewFromObject(View view, Object object) {
- return view==object;
- }
- @Override
- public Object instantiateItem(ViewGroup container, int position) {
- ImageView imageView=new ImageView(MainActivity.this);
- ImageLoader.getInstance().displayImage(imagelist.get(position%imagelist.size()),imageView,appliction.getImageOptions());
- container.addView(imageView);
- return imageView;
- }
- @Override
- public void destroyItem(ViewGroup container, int position, Object object) {
- container.removeView((View) object);
- }
- }
- public void jian(){
- pager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
- @Override
- public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
- }
- @Override
- public void onPageSelected(int position) {
- switch (position%imagelist.size()){
- case :
- rg.check(R.id.rb1);
- break;
- case :
- rg.check(R.id.rb2);
- break;
- case :
- rg.check(R.id.rb3);
- break;
- }
- }
- @Override
- public void onPageScrollStateChanged(int state) {
- }
- });
- rg.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
- @Override
- public void onCheckedChanged(RadioGroup group, @IdRes int checkedId) {
- switch (checkedId%imagelist.size()){
- case R.id.rb1:
- pager.setCurrentItem();
- break;
- case R.id.rb2:
- pager.setCurrentItem();
- break;
- case R.id.rb3:
- pager.setCurrentItem();
- break;
- }
- }
- });
- }
- }
- public class MyBaseadapter extends BaseAdapter {
- private Context context;
- private List<Bean.ResultBean.DataBean> list;
- public MyBaseadapter(Context context, List<Bean.ResultBean.DataBean> list){
- this.context=context;
- this.list=list;
- }
- public void sss(List<Bean.ResultBean.DataBean> data, boolean flag){
- for (Bean.ResultBean.DataBean s: data) {
- if (flag){
- list.add(s);
- }else{
- list.add(,s);
- }
- }
- notifyDataSetChanged();
- }
- @Override
- public int getCount() {
- return list!=null?list.size():;
- }
- @Override
- public Object getItem(int position) {
- return list.get(position);
- }
- @Override
- public long getItemId(int position) {
- return position;
- }
- @Override
- public View getView(int position, View convertView, ViewGroup parent) {
- if (position%==){
- convertView=View.inflate(context,R.layout.item,null);
- ImageView image= (ImageView) convertView.findViewById(R.id.image);
- TextView tv= (TextView) convertView.findViewById(R.id.tv);
- tv.setText(list.get(position).getTitle());
- ImageLoader.getInstance().displayImage(list.get(position).getAlbums().get(),image,appliction.getImageOptions());
- }else{
- convertView=View.inflate(context,R.layout.item2,null);
- ImageView image1= (ImageView) convertView.findViewById(R.id.image1);
- TextView tv1= (TextView) convertView.findViewById(R.id.tv1);
- tv1.setText(list.get(position).getTitle());
- ImageLoader.getInstance().displayImage(list.get(position).getAlbums().get(),image1,appliction.getImageOptions());
- }
- return convertView;
- }
- }
studio无限轮播的更多相关文章
- iOS开发之三个Button实现图片无限轮播(参考手机淘宝,Swift版)
这两天使用Reveal工具查看"手机淘宝"App的UI层次时,发现其图片轮播使用了三个UIButton的复用来实现的图片循环无缝滚动.于是乎就有了今天这篇博客,看到“手机淘宝”这个 ...
- iOS:实现图片的无限轮播(二)---之使用第三方库SDCycleScrollView
iOS:实现图片的无限轮播(二)---之使用第三方库SDCycleScrollView 时间:2016-01-19 19:13:43 阅读:630 评论:0 收藏:0 ...
- iOS开发之ImageView复用实现图片无限轮播
在上篇博客中iOS开发之多图片无缝滚动组件封装与使用给出了图片无限轮播的实现方案之一,下面在给出另一种解决方案.今天博客中要说的就是在ScrollView上贴两个ImageView, 把ImageVi ...
- iOS开发UI篇—无限轮播(循环利用)
iOS开发UI篇—无限轮播(循环利用) 一.无限轮播 1.简单说明 在开发中常需要对广告或者是一些图片进行自动的轮播,也就是所谓的无限滚动. 在开发的时候,我们通常的做法是使用一个UIScrollV ...
- iOS开发UI篇—无限轮播(新闻数据展示)
iOS开发UI篇—无限轮播(新闻数据展示) 一.实现效果 二.实现步骤 1.前期准备 (1)导入数据转模型的第三方框架MJExtension (2)向项目中添加保存有“新闻”数据的pli ...
- iOS开发UI篇—无限轮播(循环展示)
iOS开发UI篇—无限轮播(循环展示) 一.简单说明 之前的程序还存在一个问题,那就是不能循环展示,因为plist文件中只有五个数组,因此第一个和最后一个之后就没有了,下面介绍处理这种循环展示问题的小 ...
- iOS开发UI篇—无限轮播(功能完善)
iOS开发UI篇—无限轮播(功能完善) 一.自动滚动 添加并设置一个定时器,每个2.0秒,就跳转到下一条. 获取当前正在展示的位置. [self addNSTimer]; } -(void)addNS ...
- Android--ViewPager的无限轮播
ViewPage_RadioButton实现带小圆点的无限轮播,效果还能凑合着用. 1.在ViewPage的监听里面这样处理 @Override public void onPageSelected( ...
- Swift应用案例 1.无限轮播
从今天开始,我学习的重点开始转向Swift,并且会分享一些自己学习的心得体会,今天给大家带来的的是无限轮播.广告页的无限轮播是非常常见的一个功能,大多数APP都有,大多数程序员也都实现过,今天我们 ...
随机推荐
- 基于缓存或zookeeper的分布式锁实现
缓存锁 我们常常将缓存作为分布式锁的解决方案,但是却不能单纯的判断某个 key 是否存在 来作为锁的获得依据,因为无论是 exists 和 get 命名都不是线程安全的,都无法保证只有一个线程可以获 ...
- 音频编辑器 OcenAudio v3.1.9.0 绿色便携版
下载地址:点我 基本介绍 ocenaudio是一款跨平台的,易于使用的,快速的,功能强大的,好用的音频编辑软件.该软件支持Virtual Studio Technology插件,美观.统一的跨平台界面 ...
- MyBatis从入门到精通(十一):MyBatis高级结果映射之一对多映射
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解MyBatis中如何使 ...
- android_layout_linearlayout(一)
这几天一直在研究线性布局这块,记录下一些研究心得,作为参考之用. 一.金刚钻:(线性布局,英文名 linearLayout) 布局xml文件中统大者是一个线性布局,它的长宽都已经fill_parent ...
- 修改mysql错误日志级别
show variables like '%log_warnings%'; 1代表开启warning信息,0代表关闭warning信息 set session log_warnings=0; set ...
- Java 内存映射文件
import java.io.*; import java.nio.MappedByteBuffer; import java.nio.channels.FileChannel; import jav ...
- 【并查集】连接格点-C++
连接格点 描述 有一个M行N列的点阵,相邻两点可以相连.一条纵向的连线花费一个单位,一条横向的连线花费两个单位.某些点之间已经有连线了,试问至少还需要花费多少个单位才能使所有的点全部连通. 输入 第一 ...
- Edgeboard试用 — 基于CIFAR10分类模型的移植
前言 在上一次的测试中,我们按照官方给的流程,使用EasyDL快速实现了一个具有性别检测功能的人脸识别系统,那么今天,我们将要试一下通过Paddlepaddle从零开始,训练一个自己的多分类模型,并进 ...
- Asp.Net Core SwaggerUI 接入
Asp.Net Core SwaggerUI 接入 简单了解 swagger的目的简单来说就是,不用为每个接口手动写接口文档,因为它是根据接口自动生成的,接口更改时文档也同步更新,减少了手动更新的麻烦 ...
- Linux基础学习整理
linux学习记录 下载地址 centos 下载地址: 网易镜像:http://mirrors.163.com/centos/6/isos/ 搜狐镜像:http://mirrors.sohu.com/ ...