您的位置:首页 > 其它

安卓广告图轮播banner

2016-07-08 14:57 106 查看
广告轮播图,能够轮询播放图片。导航点有点不明显,修改下布局透明度就可以了。







布局

<code class="hljs xml has-numbering"><span class="hljs-pi"><?xml version="1.0" encoding="utf-8"?></span>
<span class="hljs-tag"><<span class="hljs-title">LinearLayout</span> <span class="hljs-attribute">xmlns:android</span>=<span class="hljs-value">"http://schemas.android.com/apk/res/android"</span>
<span class="hljs-attribute">xmlns:tools</span>=<span class="hljs-value">"http://schemas.android.com/tools"</span>
<span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span>
<span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"match_parent"</span>
<span class="hljs-attribute">android:orientation</span>=<span class="hljs-value">"vertical"</span>
<span class="hljs-attribute">tools:context</span>=<span class="hljs-value">"teaen.com.example.cgx_pc.autoplay_forcsdn.MainActivity"</span>></span>

<span class="hljs-tag"><<span class="hljs-title">RelativeLayout
</span>    <span class="hljs-attribute">android:layout_marginTop</span>=<span class="hljs-value">"10dp"</span>
<span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span>
<span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"200dp"</span>></span>

<span class="hljs-tag"><<span class="hljs-title">android.support.v4.view.ViewPager
</span>        <span class="hljs-attribute">android:id</span>=<span class="hljs-value">"@+id/viewPager"</span>
<span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span>
<span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"match_parent"</span>></span>
<span class="hljs-tag"></<span class="hljs-title">android.support.v4.view.ViewPager</span>></span>

<span class="hljs-comment"><!--导航点容器--></span>
<span class="hljs-tag"><<span class="hljs-title">LinearLayout
</span>        <span class="hljs-attribute">android:orientation</span>=<span class="hljs-value">"horizontal"</span>
<span class="hljs-attribute">android:id</span>=<span class="hljs-value">"@+id/dot_container"</span>
<span class="hljs-attribute">android:background</span>=<span class="hljs-value">"#20c0c0c0"</span>
<span class="hljs-attribute">android:gravity</span>=<span class="hljs-value">"center"</span>
<span class="hljs-attribute">android:layout_alignParentBottom</span>=<span class="hljs-value">"true"</span>
<span class="hljs-attribute">android:layout_width</span>=<span class="hljs-value">"match_parent"</span>
<span class="hljs-attribute">android:layout_height</span>=<span class="hljs-value">"40dp"</span>></span>
<span class="hljs-tag"></<span class="hljs-title">LinearLayout</span>></span>

<span class="hljs-tag"></<span class="hljs-title">RelativeLayout</span>></span>

<span class="hljs-tag"></<span class="hljs-title">LinearLayout</span>></span>
</code><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li><li>21</li><li>22</li><li>23</li><li>24</li><li>25</li><li>26</li><li>27</li><li>28</li><li>29</li><li>30</li><li>31</li><li>32</li><li>33</li><li>34</li></ul>

pagerAdapter

<code class="hljs java has-numbering"><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MyAdpater</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">PagerAdapter</span> {</span>
<span class="hljs-keyword">private</span> List<ImageView> list;

<span class="hljs-keyword">public</span> <span class="hljs-title">MyAdpater</span>(List<ImageView> list){
<span class="hljs-keyword">this</span>.list=list;
}

<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">int</span> <span class="hljs-title">getCount</span>() {
<span class="hljs-keyword">return</span> list.size();
}

<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">boolean</span> <span class="hljs-title">isViewFromObject</span>(View view, Object object) {
<span class="hljs-keyword">return</span> view==object;
}

<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> Object <span class="hljs-title">instantiateItem</span>(ViewGroup container, <span class="hljs-keyword">int</span> position) {
container.addView(list.get(position));
<span class="hljs-keyword">return</span> list.get(position);
}

<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">destroyItem</span>(ViewGroup container, <span class="hljs-keyword">int</span> position, Object object) {
container.removeView((View) object);
}
}
</code><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li><li>21</li><li>22</li><li>23</li><li>24</li><li>25</li><li>26</li><li>27</li><li>28</li><li>29</li><li>30</li></ul>

main

<code class="hljs java has-numbering"><span class="hljs-keyword">import</span> android.os.SystemClock;
<span class="hljs-keyword">import</span> android.support.v4.view.ViewPager;
<span class="hljs-keyword">import</span> android.support.v7.app.AppCompatActivity;
<span class="hljs-keyword">import</span> android.os.Bundle;
<span class="hljs-keyword">import</span> android.widget.ImageView;
<span class="hljs-keyword">import</span> android.widget.LinearLayout;
<span class="hljs-keyword">import</span> java.util.ArrayList;
<span class="hljs-keyword">import</span> java.util.List;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MainActivity</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">AppCompatActivity</span>  {</span>

<span class="hljs-keyword">private</span> ViewPager viewPager;
<span class="hljs-keyword">private</span> LinearLayout container;
<span class="hljs-keyword">private</span> ArrayList<ImageView> list;
<span class="hljs-keyword">private</span> <span class="hljs-keyword">int</span>[] picSource={R.mipmap.another_girl,R.mipmap.gao_yuanyuan,R.mipmap.liu_shishi};
<span class="hljs-keyword">private</span> <span class="hljs-keyword">int</span> currentNum;

<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onCreate</span>(Bundle savedInstanceState) {
<span class="hljs-keyword">super</span>.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

viewPager = (ViewPager) findViewById(R.id.viewPager);
container = (LinearLayout) findViewById(R.id.dot_container);
<span class="hljs-comment">//给viewpager设置适配器</span>
MyAdpater adpater = <span class="hljs-keyword">new</span> MyAdpater(getList());
viewPager.setAdapter(adpater);
<span class="hljs-comment">//初始化导航点</span>
initDotImagView();
<span class="hljs-comment">//给Viewpager设置监听</span>
viewPager.addOnPageChangeListener(<span class="hljs-keyword">new</span> ViewPager.SimpleOnPageChangeListener(){
<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onPageSelected</span>(<span class="hljs-keyword">int</span> position) {
currentNum=position;
<span class="hljs-comment">//page改变后重新刷新dotImageView</span>
<span class="hljs-keyword">for</span> (<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i <container.getChildCount() ; i++) {
ImageView dot = (ImageView) container.getChildAt(i);
dot.setImageResource(R.mipmap.page);
<span class="hljs-keyword">if</span>(i==position)
dot.setImageResource(R.mipmap.page_now);
}
}
});
<span class="hljs-comment">//自动播放</span>
initAuotPlay();
}

<span class="hljs-keyword">private</span> <span class="hljs-keyword">void</span> <span class="hljs-title">initDotImagView</span>() {
<span class="hljs-comment">//获取布局属性</span>
LinearLayout.LayoutParams params = <span class="hljs-keyword">new</span> LinearLayout.LayoutParams(-<span class="hljs-number">2</span>, -<span class="hljs-number">2</span>);
params.leftMargin=<span class="hljs-number">20</span>;
params.rightMargin=<span class="hljs-number">20</span>;
<span class="hljs-keyword">for</span> (<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i <picSource.length ; i++) {
ImageView imageView = <span class="hljs-keyword">new</span> ImageView(<span class="hljs-keyword">this</span>);
imageView.setImageResource(R.mipmap.page);
<span class="hljs-comment">//第一张图</span>
<span class="hljs-keyword">if</span>(i==<span class="hljs-number">0</span>)
imageView.setImageResource(R.mipmap.page_now);
imageView.setLayoutParams(params);
container.addView(imageView);
}
}

<span class="hljs-comment">//返回List<ImageView></span>
<span class="hljs-keyword">private</span> List<ImageView> <span class="hljs-title">getList</span>() {
list = <span class="hljs-keyword">new</span> ArrayList<>();
<span class="hljs-keyword">for</span> (<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i <picSource.length ; i++) {
ImageView imageView = <span class="hljs-keyword">new</span> ImageView(<span class="hljs-keyword">this</span>);
imageView.setImageResource(picSource[i]);
list.add(imageView);
}
<span class="hljs-keyword">return</span> list;

}

<span class="hljs-keyword">private</span> <span class="hljs-keyword">void</span> <span class="hljs-title">initAuotPlay</span>() {
<span class="hljs-keyword">new</span> Thread(<span class="hljs-keyword">new</span> Runnable() {
<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">run</span>() {
<span class="hljs-keyword">while</span> (<span class="hljs-keyword">true</span>){
viewPager.post(<span class="hljs-keyword">new</span> Runnable() {
<span class="hljs-annotation">@Override</span>
<span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">run</span>() {
viewPager.setCurrentItem(currentNum);
}
});
<span class="hljs-comment">//播放间隔3s</span>
SystemClock.sleep(<span class="hljs-number">3000</span>);
currentNum=(currentNum+<span class="hljs-number">1</span>)%picSource.length;
}}
}).start();
}
}
</code>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: