Android 뉴스 인터페이스 시 뮬 레이 션 ListView 와 ViewPager 의 응용

아 날로 그 뉴스 APP 의 인터페이스

1)ListView 를 쓰기 전에 레이아웃 을 작성 합 니 다.
 여기에 두 가지 Item 의 레이아웃 이 있 습 니 다.

<?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="100dp"
  android:padding="10dp">


  <ImageView
    android:layout_width="100dp"
    android:layout_height="60dp"
    android:id="@+id/imageView"
    android:background="@mipmap/ic_launcher"
    android:layout_centerVertical="true"
    android:layout_alignParentRight="true" />

  <TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="New Text"
    android:id="@+id/tv_title"
    android:maxLines="3"
    android:layout_marginRight="10dp"
    android:layout_alignParentTop="true"
    android:layout_alignParentLeft="true"
    android:layout_toLeftOf="@+id/imageView" />

  <TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceSmall"
    android:text="Small Text"
    android:id="@+id/tv_time"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="true"/>
</RelativeLayout>

activity_item

<?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="wrap_content"
  android:padding="10dp">

  <TextView
    android:id="@+id/tv_title"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="@string/app_name"
    android:singleLine="true"/>

  <LinearLayout
    android:id="@+id/line1"
    android:layout_width="match_parent"
    android:layout_height="60dp"
    android:layout_below="@id/tv_title"
    android:layout_marginTop="10dp">

    <ImageView
      android:id="@+id/imageView1"
      android:layout_width="100dp"
      android:layout_height="60dp"
      android:layout_weight="1"
      android:layout_marginRight="10dp"
      android:background="@mipmap/ic_launcher" />

    <ImageView
      android:id="@+id/imageView2"
      android:layout_width="100dp"
      android:layout_height="60dp"
      android:layout_weight="1"
      android:layout_marginRight="10dp"
      android:background="@mipmap/ic_launcher" />

    <ImageView
      android:id="@+id/imageView3"
      android:layout_width="100dp"
      android:layout_height="60dp"
      android:layout_weight="1"
      android:background="@mipmap/ic_launcher" />
  </LinearLayout>

  <TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textAppearance="?android:attr/textAppearanceSmall"
    android:text="Small Text"
    android:id="@+id/tv_time"
    android:layout_below="@id/line1"
    android:layout_alignParentLeft="true"/>


</RelativeLayout>

activity_item2
첫 번 째 는 한 장의 그림 이 고,두 번 째 는 세 장의 그림 이다.
ListView 에 추 가 된 머리 레이아웃 은 ViewPager 로 미 끄 러 지 는 효 과 를 구현 합 니 다.

<?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="match_parent">

  <android.support.v4.view.ViewPager
    android:id="@+id/vp"
    android:layout_width="match_parent"
    android:layout_height="200dp" />

  <TextView
    android:id="@+id/tv_msg"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:layout_marginBottom="5dp"
    android:layout_alignBottom="@+id/vp"
    android:textColor="#ddd"
    android:text="        "
    android:singleLine="true" />

</RelativeLayout>

activity_item_header
마지막 으로 ListView 의 레이아웃 입 니 다.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:padding="10dp"
  tools:context="com.dragon.android.baseadapter.MainActivity">

  <ListView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:scrollbars="none"
    android:dividerHeight="1dp"
    android:divider="#ccc"
    android:id="@+id/listView"/>
</RelativeLayout>

activity_main
2)ListView 에 표시 할 데 이 터 는 네트워크 요청 을 하지 않 고 스스로 설정 합 니 다.

<?xml version="1.0" encoding="utf-8"?>
<resources>

  <string-array name="titles">
    <item>             ,           。                  。</item>
    <item> 2008     ,               ,        、       ,         。</item>
    <item>     ,                    。</item>
    <item>          ,      “       ”  。</item>
    <item>         ,            。        ,                 。</item>
    <item>6 30   ,               。</item>
    <item>                  ,    ,          ,      ,      。</item>
  </string-array>

  <string-array name="msgs">
    <item>        </item>
    <item>     :       </item>
    <item>   ,       </item>
    <item>   8 :        </item>
    <item>          </item>
  </string-array>

</resources>

arrays
그림 자원 은 자 유 롭 게 추가 할 수 있다.
3)사용자 정의 어댑터 계승 BaseAdapter:

package com.dragon.android.baseadapter;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Locale;

/**
 * Created by Auser on 2016/9/8.
 */
public class MyAdapter extends BaseAdapter {

  private final Context context;
  private List<Data> mData;

  public MyAdapter(Context context, List<Data> data) {
    this.mData = data;
    this.context = context;
  }

  /**
   * @return item    
   */
  @Override
  public int getCount() {
    return mData == null ? 0 : mData.size();
  }

  /**
   * @param position
   * @param convertView <  :      Item        
   * @param parent
   * @return
   */
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    View view;
    Data data = getItem(position);
    if (position % 3 == 0) {
      view = LayoutInflater.from(context).inflate(R.layout.acyivity_item_2, parent, false);
      ImageView imageView1 = (ImageView) view.findViewById(R.id.imageView1);
      ImageView imageView2 = (ImageView) view.findViewById(R.id.imageView2);
      ImageView imageView3 = (ImageView) view.findViewById(R.id.imageView3);
      imageView1.setImageResource(data.getImgResId()[0]);
      imageView2.setImageResource(data.getImgResId()[1]);
      imageView3.setImageResource(data.getImgResId()[2]);

    } else {
      view = LayoutInflater.from(context).inflate(R.layout.activity_item, parent, false);
      ImageView imageView = (ImageView) view.findViewById(R.id.imageView);
      imageView.setImageResource(data.getImgResId()[0]);
    }
    TextView tv_title = (TextView) view.findViewById(R.id.tv_title);
    tv_title.setText(data.getTitle());

    TextView tv_time = (TextView) view.findViewById(R.id.tv_time);
    String time = new SimpleDateFormat("HH:mm", Locale.CHINA).format(new Date(data.getTime()));
    tv_time.setText(time);
    return view;
  }

  /**
   *         ,          position       
   *   Item           ,    getView        Item    
   *
   * @param position      Item    
   * @return
   */
  @Override
  public Data getItem(int position) {
    // Log.d("TAG", position + "");
    return mData.get(position);
  }

  /**
   * @param position        ListView  Item         ,              
   * @return
   */
  @Override
  public long getItemId(int position) {
    return 10086;
  }

}

MyAdapter
4)머리 레이아웃 은 ViewPager 를 사용 하여 이 루어 지기 때문에 사용자 정의 어댑터 를 추가 하여 PagerAdapter 를 계승 해 야 합 니 다.

package com.dragon.android.baseadapter;

import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import java.util.List;

/**
 * Created by Auser on 2016/9/8.
 */
class MyPagerAdapter extends PagerAdapter {

  private List<ImageView> mList;

  public MyPagerAdapter(List<ImageView> mList) {
    this.mList = mList;
  }

  /**
   *   ViewPager          
   * @return       
   */
  @Override
  public int getCount() {

    // 2 31  -1
    // mList.size=5:0--4
    // position:0---9
    // 0%5=0,4%5=4,
    // 5%5=0,6%5=1....9%5=4
    return Integer.MAX_VALUE;
  }

  /**
   *   item.container:  .--->ViewPager
   * @param container
   * @param position
   * @return
   */
  @Override
  public Object instantiateItem(ViewGroup container, int position) {
    //  ImageView   ViewPager   .
    container.addView(mList.get(position % mList.size()));

    return mList.get(position % mList.size());
  }

  /**
   *      view         .
   * @param view
   * @param obj
   * @return
   */
  @Override
  public boolean isViewFromObject(View view, Object obj) {

    return view == obj;
  }

  /**
   *     item
   * @param container
   * @param position
   * @param object
   */
  @Override
  public void destroyItem(ViewGroup container, int position, Object object) {
    //         
    container.removeView(mList.get(position % mList.size()));
  }

}

MyPagerAdapter
이 안 에는 ViewPager 가 미 끄 러 질 때의 순환 효 과 를 어떻게 실현 하 는 지 주의해 야 한다.즉,매우 큰 경 계 를 설정 하고 순환 적 으로 표시 하 는 것 이다.
5)보 여줄 데 이 터 를 저장 할 용기 가 필요 합 니 다.여기에 Data 클래스 를 패키지 합 니 다.

package com.dragon.android.baseadapter;

import java.util.Arrays;

/**
 * Created by Auser on 2016/9/8.
 */
public class Data {

  private int[] imgResId;
  private String title;
  private long time;

  @Override
  public String toString() {
    return "Data{" +
        "imgResId=" + Arrays.toString(imgResId) +
        ", title='" + title + '\'' +
        ", time=" + time +
        '}';
  }

  public Data() {
  }

  public Data(String title, int[] imgResId, long time) {
    this.imgResId = imgResId;
    this.title = title;
    this.time = time;
  }

  public int[] getImgResId() {
    return imgResId;
  }

  public void setImgResId(int[] imgResId) {
    this.imgResId = imgResId;
  }

  public String getTitle() {
    return title;
  }

  public void setTitle(String title) {
    this.title = title;
  }

  public long getTime() {
    return time;
  }

  public void setTime(long time) {
    this.time = time;
  }
}

Data
6)마지막 으로 MainActivity 에서 ListView 와 ViewPager 설정 어댑터(ViewPager 의 미끄럼 에 따라 텍스트 가 동기 화 됨)

package com.dragon.android.baseadapter;

import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

  private ListView listView;
  private List<Data> mData;
  private List<ImageView> mList;
  private ViewPager mVp;
  private TextView mTv;

  private int[] imgResIds = {R.mipmap.c1, R.mipmap.c2, R.mipmap.c3,
      R.mipmap.c4, R.mipmap.c5, R.mipmap.c6, R.mipmap.c7, R.mipmap.c8,
      R.mipmap.c9, R.mipmap.c10, R.mipmap.c11, R.mipmap.c12, R.mipmap.c13};

  private int[] imageHeaderIds = {R.mipmap.a1,R.mipmap.a2,R.mipmap.a3,R.mipmap.a4,R.mipmap.a5};

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    listView = (ListView) findViewById(R.id.listView);
    String[] stringArray = getResources().getStringArray(R.array.titles);

    mData = new ArrayList<>();
    initData(stringArray);

    addHeader();

    MyAdapter myAdapter = new MyAdapter(this, mData);
    listView.setAdapter(myAdapter);
  }

  /**
   *        ViewPager
   */
  private void addHeader() {
    View view = getLayoutInflater().from(this).inflate(R.layout.activity_item_header, listView, false);
    listView.addHeaderView(view);

    mVp = (ViewPager) view.findViewById(R.id.vp);
    mTv = (TextView) view.findViewById(R.id.tv_msg);
    String[] msgs = getResources().getStringArray(R.array.msgs);

    //      .            
    mList = new ArrayList<ImageView>();
    for (int i = 0; i < imageHeaderIds.length; i++) {
      ImageView iv = new ImageView(this);
      iv.setBackgroundResource(imageHeaderIds[i]);
      mList.add(iv);
    }
    MyPagerAdapter adapter = new MyPagerAdapter(mList);
    mVp.setAdapter(adapter);

    //   ViewPager        
    mVp.setCurrentItem(1000 * mList.size());

    // mVp.setOnPageChangeListener(listener);
    mVp.addOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {

      @Override
      public void onPageSelected(int position) {
        String[] msgs = getResources().getStringArray(R.array.msgs);

        //      ViewPager      
        mTv.setText(msgs[position % mList.size()]);
      }
    });
  }

  /**
   *      
   * @param stringArray
   */
  private void initData(String[] stringArray) {
    int j = 0;
    for (int i = 0; i < stringArray.length; i++) {
      long l = System.currentTimeMillis();
      if (i % 3 == 0) {
        mData.add(new Data(stringArray[i], new int[]{imgResIds[j++], imgResIds[j++], imgResIds[j++]}, l + 1000000 * i));
      } else {
        mData.add(new Data(stringArray[i], new int[]{imgResIds[j++]}, l + 1000000 * i));
      }
    }
  }
}
이상 은 바로 뉴스 인터페이스의 모 의 사례 입 니 다.필요 한 친구 가 있 으 면 볼 수 있 습 니 다.여러분 이 본 사이트 에 대한 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기