안 드 로 이 드 라운드 이미지 전시 효과 구현
논 리 를 실현 하 다
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 ); } }
이상 은 본 고의 모든 내용 입 니 다. 여러분 의 학습 에 도움 이 되 고 호스트 도 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
vlan 포트 격리이러한 경우 PC 간에는 통신이 허용되지 않지만 모든 PC는 서버나 게이트웨이와 통신할 수 있습니다. 토폴로지는 다음과 같습니다. 위의 기능과 같이 MAC 주소 기반의 액세스 제어를 사용하면 실현할 수 있지만 조작하...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.