MainActivity
package com.example.a24476.week3day3;
import android.annotation.SuppressLint;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.TypedValue;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
private ViewPager banner;
private TextView desc;
private LinearLayout dots;
private BannerAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
banner = findViewById(R.id.banner);
desc = findViewById(R.id.desc);
dots = findViewById(R.id.dots);
adapter = new BannerAdapter(this);
banner.setAdapter(adapter);
banner.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
//缓存的点
private int cacheIndex = -1;
//页面滚动
@Override
public void onPageScrolled(int i, float v, int i1) {
}
//页面选择
@Override
public void onPageSelected(int i) {
//改变文件
desc.setText(adapter.getItem(i).getTitle());
//改变当前点
dots.getChildAt(i % dots.getChildCount()).setSelected(true);
//还原原来的点
if (cacheIndex >= 0) {
dots.getChildAt(cacheIndex % dots.getChildCount()).setSelected(false);
}
cacheIndex = i;
}
@Override
public void onPageScrollStateChanged(int i) {
}
});
initData();
}
private void initData() {
NetUtil.yibu("https://api.tianapi.com/wxnew/?key=c4aa776e0a51d57d6750511e2baa46b6&num=6&page=1"
, BannerResponse.class, new NetUtil.CallBack<BannerResponse>() {
@Override
public void getdata(BannerResponse bannerResponse) {
if (bannerResponse == null || !bannerResponse.isSuccess()) {
Toast.makeText(MainActivity.this, "请求错误", Toast.LENGTH_SHORT).show();
return;
}
adapter.setDatas(bannerResponse.getNewslist());
initDot(bannerResponse.getNewslist().size());
//切换到中间
int center = adapter.getCount() / 2;
center = center - center % bannerResponse.getNewslist().size();
banner.setCurrentItem(center);
//开启轮播
startlooper();
}
});
}
@SuppressLint("HandlerLeak")
private Handler mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
banner.setCurrentItem(banner.getCurrentItem() + 1);
mHandler.sendEmptyMessageDelayed(0, 2000);
}
};
private void startlooper() {
mHandler.removeMessages(0);
mHandler.sendEmptyMessageDelayed(0, 2000);
}
//初始化小圆点
private void initDot(int size) {
dots.removeAllViews();
for (int i = 0; i < size; i++) {
ImageView imageView = new ImageView(this);
imageView.setBackgroundResource(R.drawable.selector_dot);
//布局参数: 宽高包裹 左右8dp
LinearLayout.LayoutParams params =
new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT);
int margin = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 2, getResources().getDisplayMetrics());
params.leftMargin = margin;
params.rightMargin = margin;
dots.addView(imageView, params);
}
}
}
BannerAdapter适配器
package com.example.a24476.week3day3;
import android.content.Context;
import android.support.annotation.NonNull;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import com.nostra13.universalimageloader.core.ImageLoader;
import java.util.ArrayList;
import java.util.List;
public class BannerAdapter extends PagerAdapter {
private List<BannerResponse.Banner> mDatas;
private Context context;
public BannerAdapter(Context context) {
this.context = context;
mDatas = new ArrayList<>();
}
@Override
public int getCount() {
return mDatas.size() > 0 ? 5000 : 0;
}
public BannerResponse.Banner getItem(int position) {
return mDatas.get(position % mDatas.size());
}
public void setDatas(List<BannerResponse.Banner> datas) {
mDatas.clear();
if (datas != null) {
mDatas.addAll(datas);
}
notifyDataSetChanged();
}
@Override
public boolean isViewFromObject(@NonNull View view, @NonNull Object o) {
return view == o;
}
@NonNull
@Override
public Object instantiateItem(@NonNull ViewGroup container, int position) {
ImageView imageView = new ImageView(context);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
container.addView(imageView);
ImageLoader.getInstance().displayImage(getItem(position).getPicUrl(), imageView);
return imageView;
}
@Override
public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
container.removeView((View) object);
}
}
activity_main.xml布局
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout 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=".MainActivity">
<android.support.v4.view.ViewPager
android:id="@+id/banner"
android:layout_width="0dp"
android:layout_height="200dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<LinearLayout
android:id="@+id/dots"
android:layout_width="wrap_content"
android:layout_height="0dp"
android:orientation="horizontal"
app:layout_constraintRight_toRightOf="@id/banner"
app:layout_constraintBottom_toBottomOf="@id/banner"
android:padding="8dp"
/>
<TextView
android:id="@+id/desc"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:maxLines="1"
android:ellipsize="end"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toLeftOf="@id/dots"
app:layout_constraintBottom_toBottomOf="@id/banner"/>
</android.support.constraint.ConstraintLayout>
==============================
BannerActivity
package com.example.a24476.week3day3;
import android.content.Context;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
import com.youth.banner.Banner;
import com.youth.banner.BannerConfig;
import com.youth.banner.loader.ImageLoader;
import com.youth.banner.loader.ImageLoaderInterface;
import java.util.ArrayList;
import java.util.List;
public class BannerActivity extends AppCompatActivity {
private Banner banner;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_banner);
banner = findViewById(R.id.banner);
//设置banner样式
banner.setBannerStyle(BannerConfig.CIRCLE_INDICATOR_TITLE_INSIDE);
//设置图片加载器
banner.setImageLoader(new ImageLoaderInterface<ImageView>() {
@Override
public void displayImage(Context context, Object path, ImageView imageView) {
BannerResponse.Banner banner = (BannerResponse.Banner) path;
com.nostra13.universalimageloader.core.ImageLoader.getInstance()
.displayImage(banner.getPicUrl(), imageView);
}
@Override
public ImageView createImageView(Context context) {
ImageView imageView = new ImageView(context);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
return imageView;
}
});
initData();
}
private void initData() {
NetUtil.yibu("https://api.tianapi.com/wxnew/?key=c4aa776e0a51d57d6750511e2baa46b6&num=6&page=1", BannerResponse.class, new NetUtil.CallBack<BannerResponse>() {
@Override
public void getdata(BannerResponse o) {
//设置图片集合
banner.setImages(o.getNewslist());
banner.setBannerTitles(getTitles(o));
//banner设置方法全部调用完毕时最后调用
banner.start();
}
});
}
private List<String> getTitles(BannerResponse bannerResponse) {
List<String> result = new ArrayList<>();
for (BannerResponse.Banner banner: bannerResponse.getNewslist()) {
result.add(banner.getTitle());
}
return result;
}
}
banner.xml布局
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<com.youth.banner.Banner
android:id="@+id/banner"
android:layout_width="0dp"
android:layout_height="200dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:indicator_width="8dp"
app:indicator_height="8dp"
app:indicator_drawable_selected="@drawable/shape_sel_dot"
app:indicator_drawable_unselected="@drawable/shape_normal_dot"
/>
</android.support.constraint.ConstraintLayout>
drawable配置
1.
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/shape_sel_dot" android:state_selected="true" />
<item android:drawable="@drawable/shape_normal_dot" />
</selector>
2.
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<size
android:width="8dp"
android:height="8dp" />
<solid android:color="#909090" />
</shape>
3.
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<size
android:width="8dp"
android:height="8dp" />
<solid android:color="#900000" />
</shape>