滾動新聞視圖,呃~ 其實真正的名稱我也不太清楚,姑且這樣叫吧。希望有大神可以幫忙指正,謝謝!
首先看一下這個demo的視圖:
其中,有三個部分,分別是圖片顯示部分、標題部分和滾動中的點(先這樣稱呼吧)。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="185dp" >
<LinearLayout
android:id="@+id/top_news_viewpager"
android:layout_width="fill_parent"
android:layout_height="185dp"
android:orientation="horizontal" />
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="30dp"
android:layout_alignParentBottom="true"
android:background="#88000000"
android:gravity="center_vertical"
android:orientation="horizontal" >
<TextView
android:id="@+id/top_news_title"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:layout_marginRight="8dp"
android:layout_weight="1"
android:singleLine="true"
android:text="圖片標題"
android:textColor="#F6F6F6" />
<LinearLayout
android:id="@+id/dots_ll"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginRight="5dp"
android:gravity="center"
android:orientation="horizontal" />
</LinearLayout>
</RelativeLayout>
在圖片顯示的位置上,實際上是LinearLayout,這樣方便動態的加載圖片。其他的佈局不用多說了。很簡單的。
在MianActivity中,對於滾動的視圖,我是從網上找的嗶哩嗶哩的連接---->http://www.bilibili.com/index/slideshow.json;
整理後的json數據如下:
{
"list": [
{
"img": "http://i0.hdslb.com/u_user/c6b4b30c07ddfd9ca039c1113acce585.jpg",
"link": "http://www.bilibili.com/topic/711.html",
"simg": "",
"title": "花式秀恩愛啊"
},
{
"img": "http://i2.hdslb.com/promote/1e3a969ec5f508b2e74c6268f21158bd.jpg",
"link": "http://www.bilibili.com/video/av2412947/",
"simg": "",
"title": "週刊排行榜 #259"
},
{
"img": "http://i0.hdslb.com/promote/e6bbcf75fed8e6d39826c359db72fe5b.jpg",
"link": "http://www.bilibili.com/video/av2412466/?br",
"simg": "",
"title": "獨家正版 雨色可可 10"
},
{
"img": "http://i0.hdslb.com/promote/5bc57e607a459de340f9c832f3040055.jpg",
"link": "http://www.bilibili.com/video/av2412458/?br",
"simg": "",
"title": "亞爾斯蘭戰記 第10話"
},
{
"img": "http://i1.hdslb.com/u_user/c3aa1bf61340aaaefbaef4efeb7e5c00.jpg",
"link": "http://www.bilibili.com/topic/709.html",
"simg": "",
"title": "生日快樂!"
},
{
"img": "http://i0.hdslb.com/u_user/9f295e435aa7b0d32886a034b635a758.jpg",
"link": "http://www.bilibili.com/topic/v2/708.html",
"simg": "",
"title": "啦啦啦!週末啦!"
}
],
"results": 6
}
用這個可以動態的獲取實時的網絡數據,比一般的教程中,固定的幾張圖片和標題,本人感覺要高大上許多。
這裏提到一個很好用的json格式化軟件,HiJson,真的很好用(誰用誰知道)。
對於json數據的解析,採用的是Gson來解析的。
而網絡數據的加載是採用xUtils。也是很方便的喲。
MainActivity中的一些初始化就不多說了,下面一段代碼是通過xUtils從網上截取json數據;
<span style="white-space:pre"> </span>HttpUtils httpUtils = new HttpUtils();
httpUtils.send(HttpMethod.GET, url, new RequestCallBack<String>() {
@Override
public void onFailure(HttpException arg0, String arg1) {
// TODO Auto-generated method stub
}
@Override
public void onSuccess(ResponseInfo<String> responseInfo) {
PrecessData(responseInfo.result);
}
});
其中的PrecessData()方法是對json數據進行解析和對數據的處理。
<span style="white-space:pre"> </span>protected void PrecessData(String result) {
Gson gson = new Gson();
RollViewBean viewBean = gson.fromJson(result, RollViewBean.class);
<span style="white-space:pre"> </span>//這裏的viewBean是根據json數據創建的bean類</span>
if (viewBean.list != null) {
// 加載解析出來的數據
for (ItemView item : viewBean.list) {
picUrl.add(item.img);
titleList.add(item.title);
itemList.add(item.link);
}
<span style="white-space:pre"> </span>//上面的代碼是對解析出來的數據添加的local變量中,方便使用。</span>
initDot(viewBean.list.size());
// 創建滾動view自定義組件
RollingViewPager pager = new RollingViewPager(this, dotViewList,
itemList, R.drawable.dot_normal, R.drawable.dot_focus);
<span style="white-space:pre"> </span> //上面的代碼是創建自定義的滾動視圖組件,並傳入需要的參數</span>
<span style="white-space:pre"> </span> //參數中,dotViewList的定義是private List<View> dotViewList;這個是對點的View的一個list,下面會貼出代碼。
<span style="white-space:pre"> </span>//<span style="font-family: Arial, Helvetica, sans-serif;">itemList是解析json數據是存儲的詳細連接地址。</span></span>
<span style="white-space:pre"> </span>//R.drawable.dot_normal和R.drawable.dot_focus是兩個圖片,代表圖片展示和非展示狀態是點的圖片(好難解~)
pager.setImageUrl(picUrl);//設置圖片的Url連接
pager.settitle(titleList, title);//設置圖片的連接,並傳入圖片顯示的控件
pager.setDuration(4000);//設置滾動視圖的滾動時間
pager.startRoll();//開始滾動
ll_viewPager.removeAllViews();//清空佈局
ll_viewPager.addView(pager);//將創建的view加載到佈局中
}
}
下面代碼是動態初始化點
<span style="white-space:pre"> </span>/**
* 初始化點
*
* @param size
* 點的個數
*/
private void initDot(int size) {
dotViewList = new ArrayList<View>();
ll_dot.removeAllViews();// 清空佈局,保證沒有控件
for (int i = 0; i < size; i++) {
View dotView = new View(this);
// 設置所創建出來view的大小
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(
CommonUtil.dip2px(this, 6), CommonUtil.dip2px(this, 6));
// 設置各個view的間距
layoutParams.setMargins(5, 0, 5, 0);
// 將設置好的參數添加到view中
dotView.setLayoutParams(layoutParams);
// 設置初始的顯示狀況
if (i == 0) {
dotView.setBackgroundResource(R.drawable.dot_focus);
} else {
dotView.setBackgroundResource(R.drawable.dot_normal);
}
// 將創建的view添加到集合中
dotViewList.add(dotView);
// 將創建的view添加到佈局中顯示
ll_dot.addView(dotView);
}
}
這裏用到了CommonUtils的工具類。
好了,MianActivity中大致是這樣了,下面來看看自定義的滾動視圖的代碼
首先,在創建滾動視圖的構造
<span style="white-space:pre"> </span>public RollingViewPager(MainActivity mainActivity, List<View> dotList,
List<String> itemList, int dotNormal, int dotFocus) {
super(mainActivity);
this.ct = mainActivity;
this.dotList = dotList;
this.dotNormal = dotNormal;
this.dotFocus = dotFocus;
this.itemList = itemList;
bitmapUtils = new BitmapUtils(ct);
bitmapUtils.configDefaultBitmapConfig(Config.RGB_565);
<span style="white-space:pre"> </span>//上面的2行代碼是xUtils中bitmapUtils的簡單創建和初始化配置。</span>
// 創建task
viewPagerTask = new ViewPagerTask();
<span style="white-space:pre"> </span>//這個task的作用是定時去滾動視圖
接下來是設置圖片的連接的方法
<span style="white-space:pre"> </span>/**
* 設置圖片url連接
*
* @param picUrl
* 圖片的url
*/
private List<String> picUrl;
public void setImageUrl(List<String> picUrl) {
this.picUrl = picUrl;
}
還有設置標題的方法
<span style="white-space:pre"> </span>/**
* 設置標題
*
* @param titleList
* 標題的數據
* @param title
* 標題顯示的組件
*/
private List<String> titleList;
private TextView title;
public void settitle(List<String> titleList, TextView title) {
this.titleList = titleList;
this.title = title;
// 設置顯示第一個標題的數據
if (title != null && titleList != null && titleList.size() > 0) {
title.setText(titleList.get(0));
}
}
還有設置跳轉時間的方法
<span style="white-space:pre"> </span>/**
* 設置圖片自動跳轉的時間
*
* @param i
*/
private int duration;
public void setDuration(int duration) {
this.duration = duration;
}
接下來是重要的開始滾動的方法
<span style="white-space:pre"> </span>/**
* 開始滾動
*/
private boolean hasSetAdater = false;// 判斷是否已經創建adapter
private MyViewPagerAdapter adapter;
private ViewPagerTask viewPagerTask;
public void startRoll() {
if (!hasSetAdater)// 如果沒有創建adapter
{
hasSetAdater = true;
adapter = new MyViewPagerAdapter();
RollingViewPager.this
.setOnPageChangeListener(new MyOnPagerChangeListener());
RollingViewPager.this.setAdapter(adapter);
}
handler.postDelayed(viewPagerTask, duration);
}
/*
* 創建一個handler來控制循環滾動
*/
private Handler handler = new Handler() {
public void handleMessage(android.os.Message msg) {
RollingViewPager.this.setCurrentItem(currentItem);
startRoll();
};
};
/**
* 創建一個task開執行滾動切換操作
*
* @author Administrator
*
*/
private int currentItem = 0;// 當前正在展示的
public class ViewPagerTask implements Runnable {
@Override
public void run() {
currentItem = (currentItem + 1) % dotList.size();
title.setText(titleList.get(currentItem));
handler.obtainMessage().sendToTarget();// 再次調用handle
}
}
關鍵的自定義MyViewPagerAdapter如下
<span style="white-space:pre"> </span>public class MyViewPagerAdapter extends PagerAdapter {
@Override
public int getCount() {
// TODO Auto-generated method stub
return picUrl.size();
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
// TODO Auto-generated method stub
return arg0 == arg1;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
((ViewPager) container).removeView((View) object);
}
@Override
public Object instantiateItem(ViewGroup container, final int position) {
View view = View.inflate(ct, R.layout.viewpager_item, null);//其中加載的viewpager_item是一個ImageView的佈局。
((ViewPager) container).addView(view);// 將創建的空間添加到container容器中
ImageView image = (ImageView) view.findViewById(R.id.image);
// LogUtils.d("要加載的數據url---->" + picUrl.get(position));
bitmapUtils.display(image, picUrl.get(position));// 下載圖片並顯示顯示到相應的位置
view.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
// TODO Auto-generated method stub
// LogUtils.d("你點擊了" + itemList.get(position));
Intent intent = new Intent();
intent.putExtra("url", itemList.get(position));
intent.setClass(ct, ItemActivity.class);
ct.startActivity(intent);
}
});
<span style="white-space:pre"> </span>//上面的代碼複寫了onClick方法,實現了點擊滾動視圖後跳轉到詳細內容顯示。這部分比較簡單,就不給出代碼了。
return view;
}
}
最重要的是圖片與點了聯動,如下代碼:
<span style="white-space:pre"> </span>public class MyOnPagerChangeListener implements OnPageChangeListener {
private int oldposition = 0;
@Override
public void onPageSelected(int position) {
// TODO Auto-generated method stub
currentItem = position;
if (titleList != null) {
title.setText(titleList.get(currentItem));
}
if (dotList != null) {
dotList.get(position).setBackgroundResource(dotFocus);
dotList.get(oldposition).setBackgroundResource(dotNormal);
}
oldposition = currentItem;
}
<span style="white-space:pre"> </span>//在RollingViewPager的構造中傳入點的集合dotList就是爲了聯動。</span>
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
}
至此,基本上這個demo的關鍵代碼都在這裏了,希望看客們共同學習,天天向上。
如果有需要源代碼的,qq留言。謝謝。