안 드 로 이 드 라운드 이미지 전시 효과 구현

17355 단어 네트워크 기술
본 논문 의 사례 는 여러분 에 게 안 드 로 이 드 윤방 사진 의 전 시 를 공유 하 였 으 며, 여러분 께 참고 하 시기 바 랍 니 다. 구체 적 인 내용 은 다음 과 같 습 니 다.
논 리 를 실현 하 다
1. XML 레이아웃 파일 을 만 들 고 ViewPager 를 사용 하여 라운드 그림 을 완성 합 니 다.
2. ViewPager 컨트롤 을 초기 화하 고 컨트롤 에 어댑터 를 설정 합 니 다. 만 든 어댑터 는 네 가지 방법 을 실현 합 니 다.
3. 네 가지 방법 은 getCount isView FromObject instantiate Item destroy Item
4. onCreate 방법 에서 그림 자원 을 불 러 오고 그림 ID 를 집합 에 저장 하여 그림 을 페이지 에 표시 할 수 있 도록 합 니 다. (그림 이 페이지 에 표 시 될 수 있 는 이 유 는 어댑터 의 instantiate Item 방법 에서 집합 중인 그림 요 소 를 가 져 왔 기 때 문 입 니 다)
5. 그림 아래 의 텍스트 표시: 그림 아래 에 텍스트 가 있 는 이 유 는 컨트롤 을 초기 화하 여 ViewPager 모니터 의 onPage Selected 방법 에서 tvdesc.setText(descs[position]);이렇게 하면 문자 가 그림 에 따라 전환 할 수 있 습 니 다.
6. 텍스트 아래 의 작은 원점 전환: XML 레이아웃 에 Linlayout 레이아웃 을 설정 한 다음 onCreate 방법 에 작은 원점 을 설정 하고 LinearLayout. LayoutParams layout Params = new LinearLayout. LayoutParams (10, 10) 를 통 해 설정 합 니 다.의 방법 으로 작은 원점 을 도입 합 니 다 (구체 적 인 코드 는 아래 의 initDot 방법 을 참고 할 수 있 습 니 다)
7. 작은 원점 을 페이지 전환 에 따라 전환 시 키 려 면 아래 changeDots 방법 을 정의 하여 모니터 의 onPage Selected 방법 에서 호출 할 수 있 습 니 다.
8. 그림 의 무한 라운드 방송의 실현: 어댑터 의 getCount 반환 값 을 매우 큰 값 으로 설정 할 수 있 으 며, 인 스 턴 트 Item 방법 에 position position = position% image ResIds. length 를 설정 할 수 있 습 니 다.색인 크로스 오 버 이상 을 방지 하면 그림 을 무한 라운드 로 재생 할 수 있 습 니 다. 그러나 이때 또 하나의 문 제 는 오른쪽 은 무한 라운드 로 방송 할 수 있 지만 왼쪽 은 무한 라운드 로 방송 할 수 없습니다. 이 문제 의 해결 방법 은 onCreate 방법 에서 현재 선택 한 항목 view Pager. setCurrent Item (count / 2) 을 설정 하 는 것 입 니 다.이렇게 양쪽 다 무한 윤방 이 가능 해 요.
9. 그림 자동 전환 처리: handler 체 제 를 사용 하여 페이지 의 지연 업 데 이 트 를 실현 하 는 동시에 메모리 가 넘 치지 않도록 페이지 에서 볼 때, 즉 activity 의 onStart 방법 에서 메 시 지 를 보 내 고 페이지 가 사라 질 때, 즉 onStop 방법 에서 메 시 지 를 삭제 해 야 합 니 다.
레이아웃 파일
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 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:id = "@+id/activity_main" android:layout_width = "match_parent" android:layout_height = "match_parent" tools:context = "com.example.a2_.MainActivity" >   < android.support.v4.view.ViewPager    android:id = "@+id/vp"    android:layout_width = "match_parent"    android:layout_height = "250dp" > android.support.v4.view.ViewPager >

 

< LinearLayout    android:orientation = "vertical"    android:gravity = "center"    android:background = "#66000000"    android:layout_alignBottom = "@id/vp"    android:layout_width = "match_parent"    android:layout_height = "50dp" >      < TextView      android:id = "@+id/desc"      android:text = " "      android:textColor = "#ffffff"      android:layout_width = "wrap_content"      android:layout_height = "wrap_content" />      < LinearLayout      android:id = "@+id/layout_dot"      android:orientation = "horizontal"      android:layout_width = "wrap_content"      android:layout_height = "wrap_content" >      LinearLayout >

LinearLayout >

RelativeLayout >
핵심 코드
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 package com.example.a2_;   import android.os.Handler; import android.os.Message; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.TextView;   import java.util.ArrayList;   public class MainActivity extends AppCompatActivity { private static final int UPDATE_ITEM = 1 ; private ArrayList imageViews = new ArrayList<>(); private int [] imageResIds = {R.mipmap.icon_1, R.mipmap.icon_2, R.mipmap.icon_3,      R.mipmap.icon_4, R.mipmap.icon_5};   private String[] descs = { " " , " " , " " , "Google/IO" , " 1w+" }; private ViewPager viewPager; private TextView tv_desc; private LinearLayout layout_dot; private int count = 10000000 ; private Handler handler = new Handler() {    @Override    public void handleMessage(Message msg) {      switch (msg.what) {        case UPDATE_ITEM:          upDataItem();          break ;      }      super .handleMessage(msg);    } };   @Override protected void onCreate(Bundle savedInstanceState) {    super .onCreate(savedInstanceState);    setContentView(R.layout.activity_main);      //    viewPager = (ViewPager) findViewById(R.id.vp);    tv_desc = (TextView) findViewById(R.id.desc);    layout_dot = (LinearLayout) findViewById(R.id.layout_dot);    // viewPager    viewPager.setAdapter( new MyPagerAdapter());    // viewPager    viewPager.addOnPageChangeListener( new ViewPager.OnPageChangeListener() {        //      @Override      public void onPageScrolled( int position, float positionOffset, int positionOffsetPixels) {        }        //      @Override      public void onPageSelected( int position) {        // position        position = position % imageViews.size();        // ,        tv_desc.setText(descs[position]);        changeDots(position);      }        //      @Override      public void onPageScrollStateChanged( int state) {        //        if (state == viewPager.SCROLL_STATE_IDLE) {          handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000 );        } else {          handler.removeMessages(UPDATE_ITEM);        }      }    });        //    initImage();    //    initDot();    // , //    initDescFirst();      //    viewPager.setCurrentItem(count / 2 ); //    upDataItem(); }   private void upDataItem() {    int index = viewPager.getCurrentItem();    viewPager.setCurrentItem(++index);    handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000 ); }   // private void changeDots( int position) {    //    for ( int i = 0 ; i < layout_dot.getChildCount(); i++) {      View view = layout_dot.getChildAt(i);      view.setSelected( false );    }    //    layout_dot.getChildAt(position).setSelected( true );   }   // private void initDot() {    LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams( 10 , 10 );    layoutParams.setMargins( 4 , 4 , 4 , 4 );    for ( int i = 0 ; i < imageViews.size(); i++) {      View view = new View( this );      view.setBackgroundResource(R.drawable.seletor_dot);      view.setLayoutParams(layoutParams);      layout_dot.addView(view);    } }   // , private void initDescFirst() {    tv_desc.setText(descs[ 0 ]);    changeDots( 0 ); }   // , ImageView , instantiateItem private void initImage() {    for ( int i = 0 ; i < imageResIds.length; i++) {      // ImageView      ImageView imageView = new ImageView(getApplicationContext());      imageView.setImageResource(imageResIds[i]);      imageViews.add(imageView);    } }   private class MyPagerAdapter extends PagerAdapter {      @Override    public int getCount() {      return count;    }      @Override    public boolean isViewFromObject(View view, Object object) {      // view instantiateItem      return view == object;    }      //    @Override    public Object instantiateItem(ViewGroup container, int position) {      position = position % imageResIds.length;      //      ImageView imageView = imageViews.get(position);      container.addView(imageView);      return imageView;    }      // ,, ,    @Override    public void destroyItem(ViewGroup container, int position, Object object) {        //      container.removeView((View) object);    } }   @Override protected void onStart() {    super .onStart();    // ,    handler.sendEmptyMessageDelayed(UPDATE_ITEM, 3000 ); }   @Override protected void onStop() {    super .onStop();    // ,    handler.removeCallbacksAndMessages( null ); } }
 
이상 은 본 고의 모든 내용 입 니 다. 여러분 의 학습 에 도움 이 되 고 호스트 도 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기