之前的博文中有介绍关于图片轮播的实现方式,分别为(含超链接):

今天通过使用GitHub中的开源项目android-image-indicator来简单实现APP自带图片的轮播以及加载网络图片进行轮播。

一、从GitHub上下载项目

其中介绍了简单的使用示例,大家可以看看

二、导入依赖包

(1)我尝试使用AndroidStudio2,2通过Import Module来导入下载文件中的library来导入依赖包,但本次下载的项目使用Maven来构建,

导入过程出现错误提示:Error:(2, 0) Plugin with id‘com.github.dcendents.Android-maven' not found。尝试了多种解决方案,无法有效解决依赖包导入问题。建议使用第二种方法导入

(2)在build.gradle(Module.app)中dependencies下直接添加以下代码

compile 'com.panxw.imageindicator:library:1.0.2'

添加示例如下:

添加完后,点击界面上的提示,同步以下就好。

三、演示加载APP自带图片

(1)Layout布局文件如下:

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.mly.panhouye.demo.MainActivity">

android:id="@+id/indicate_view"

android:layout_width="match_parent"

android:layout_height="match_parent">

(2)Java实现代码如下:

package com.mly.panhouye.demo;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import com.panxw.android.imageindicator.AutoPlayManager;

import com.panxw.android.imageindicator.ImageIndicatorView;

import java.util.ArrayList;

import java.util.List;

public class MainActivity extends AppCompatActivity {

ImageIndicatorView indicate_view;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

indicate_view = (ImageIndicatorView) findViewById(R.id.indicate_view);

local();

}

//系统本地图片加载

public void local() {

// 声明一个数组, 指定图片的ID

final Integer[] resArray = new Integer[] {R.mipmap.a1, R.mipmap.a2,

R.mipmap.a3, R.mipmap.a4};

// 把数组交给图片展播组件

indicate_view.setupLayoutByDrawable(resArray);

// 展播的风格

// indicate_view.setIndicateStyle(ImageIndicatorView.INDICATE_ARROW_ROUND_STYLE);

indicate_view.setIndicateStyle(ImageIndicatorView.INDICATE_USERGUIDE_STYLE);

// 显示组件

indicate_view.show();

final AutoPlayManager autoBrocastManager = new AutoPlayManager(indicate_view);

//设置开启自动广播

autoBrocastManager.setBroadcastEnable(true);

//autoBrocastManager.setBroadCastTimes(5);//loop times

//设置开始时间和间隔时间

autoBrocastManager.setBroadcastTimeIntevel(3000, 3000);

//设置循环播放

autoBrocastManager.loop();

}

}

四、加载网络图片

(1)首先在Java中自定义NetworkImageIndicatorView.class

其中在加载网络图片到imageView中使用了网络通信框架-VolLey。这里主要使用其中的ImageRequest,

ImageRequest的构造函数接收六个参数,分别代表的含义是:

第一个参数就是图片的URL地址,这个没什么需要解释的。

第二个参数是图片请求成功的回调,这里我们把返回的Bitmap参数设置到ImageView中。

第三第四个参数分别用于指定允许图片最大的宽度和高度,如果指定的网络图片的宽度或高度大于这里的最大值,则会对图片进行压缩,指定成0的话就表示不管图片有多大,都不会进行压缩。

第五个参数用于指定图片的颜色属性,Bitmap.Config下的几个常量都可以在这里使用,其中ARGB_8888可以展示最好的颜色属性,每个图片像素占据4个字节的大小,而RGB_565则表示每个图片像素占据2个字节大小。

第六个参数是图片请求失败的回调,这里我们当请求失败时在ImageView中显示一张默认图片。

package com.mly.panhouye.demo;

import android.content.Context;

import android.graphics.Bitmap;

import android.util.AttributeSet;

import android.widget.ImageView;

import com.android.volley.RequestQueue;

import com.android.volley.Response;

import com.android.volley.VolleyError;

import com.android.volley.toolbox.ImageRequest;

import com.android.volley.toolbox.Volley;

import com.panxw.android.imageindicator.ImageIndicatorView;

import java.util.List;

/**

* Created by panchengjia on 2017/1/10 0010.

*/

public class NetworkImageIndicatorView extends ImageIndicatorView {

public NetworkImageIndicatorView(Context context, AttributeSet attrs) {

super(context, attrs);

}

public NetworkImageIndicatorView(Context context) {

super(context);

}

public void setupLayoutByImageUrl(List urlList) {

for(String url: urlList) {

final ImageView imageView = new ImageView(getContext());

//load image from url and set to imageView, you can use UIL or Volley to do this work

//本次我们使用Volley

//创建一个请求对列

RequestQueue queue = Volley.newRequestQueue(getContext());

ImageRequest request = new ImageRequest(url, new Response.Listener() {

@Override

public void onResponse(Bitmap bitmap) {

imageView.setImageBitmap(bitmap);

}

}, 0, 0, Bitmap.Config.RGB_565, new Response.ErrorListener() {

@Override

public void onErrorResponse(VolleyError volleyError) {

System.out.println(volleyError);

}

});

queue.add(request);

addViewItem(imageView);

}

}

}

(2)Layout布局展示文件如下:

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/activity_main"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

tools:context="com.mly.panhouye.demo.MainActivity">

android:layout_width="match_parent"

android:layout_height="match_parent"

android:id="@+id/internet_iv">

(3)java实现代码如下:

package com.mly.panhouye.demo;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import com.panxw.android.imageindicator.AutoPlayManager;

import com.panxw.android.imageindicator.ImageIndicatorView;

import java.util.ArrayList;

import java.util.List;

public class MainActivity extends AppCompatActivity {

NetworkImageIndicatorView internet_iv;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

internet_iv= (NetworkImageIndicatorView) findViewById(R.id.internet_iv);

internet();

}

public void internet(){

final List urlList= new ArrayList();

urlList.add("http://r.photo.store.qq.com/psb?/V12kkHqD1CWRD4/1*CDpMdmLbUg.gga4PxHTxZUSZqZ1ei76FIDnprasXI!/r/dKEAAAAAAAAA");

urlList.add("http://r.photo.store.qq.com/psb?/V12kkHqD1CWRD4/40Y896PFEJ0ZdQyzrd0Nar48yCs5g9lkH3jI7zSRCQQ!/r/dKEAAAAAAAAA");

urlList.add("http://r.photo.store.qq.com/psb?/V12kkHqD1CWRD4/7oqQQKh5D5OKezdyC0geEGaTQjJirH8.GbQ9mY13aIY!/r/dKAAAAAAAAAA");

internet_iv.setupLayoutByImageUrl(urlList);

internet_iv.show();

//设置自动播放

AutoPlayManager autoBrocastManager = new AutoPlayManager(internet_iv);

autoBrocastManager.setBroadcastEnable(true);

autoBrocastManager.setBroadCastTimes(5);//循环次数设置

autoBrocastManager.setBroadcastTimeIntevel(500, 500);

autoBrocastManager.loop();

}

}

使用开源框架实现起来还是很方便的,本次演示只为实现功能,大家有时间可以优化下界面,实现自己想要的结果(网络加载中引用了本人的玉照哦,谢谢大家观赏)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

android github轮播图,Android使用开源框架ANDROID-IMAGE-INDICATOR实现图片轮播部署相关推荐

  1. html+轮播图下标跳转代码,最简单的JavaScript图片轮播代码(两种方法)

    通过改变每个图片的opacity属性: 素材图片: 代码一: 最简单的轮播广告 body, div, ul, li { margin: ; padding: ; } ul { list-style-t ...

  2. html轮播图水平传送带,经典的白富美型jQuery图片轮播插件

    图片轮播是网站中的常用功能,用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美 ...

  3. 纯css自动全屏轮播图html代码,纯CSS3代码实现简单的图片轮播

    以4张图片为例: 1.基本布局: 将4张图片左浮动横向并排放入一个div容器内,图片设置统一尺寸,div宽度设置4个图片的总尺寸,然后放入相框容器div, 相框设置1个图片的大小并设置溢出隐藏,以保证 ...

  4. html轮播图兼容ie8,多功能响应式兼容IE8图片轮播

    2016-09-27 10:02:56 前段时间在写一个官网,官网中很多地方都用到了图片轮播,但是需求中要求网站适配到IE8同时具有自适应的特点,适配各种尺寸的浏览器和移动端浏览器.于是我尝试了在网上 ...

  5. 【学会轮播图这一篇文章就足够啦】JS 网页轮播图详解 自动播放+手动播放

    轮播图已经成了页面开发中不可缺少的一部分,日常生活中随处都能见到轮播图的身影,例如平常我们购物的淘宝,京东等等,都靠着轮播图在一片 有限的区域内展现出更多的商品.这也是前端程序员最早接触到的练手小项目 ...

  6. jquery手写轮播图_用jQuery如何手写一个简单的轮播图?(附代码)

    用jQuery如何手写一个简单的轮播图?下面本篇文章通过代码示例来给大家介绍一下.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. 用 jQuery 手写轮播图 先上个效果截图: 主要 ...

  7. 【github干货】主流深度学习开源框架从入门到熟练

    文章首发于微信公众号<有三AI> [github干货]主流深度学习开源框架从入门到熟练 今天送上有三AI学院第一个github项目 01项目背景 目前深度学习框架呈百家争鸣之态势,光是为人 ...

  8. android 炫酷轮播图,一个很Nice的Android Banner轮播图库

    Android小白一枚,最近项目中有一个轮播图的需求,网上搜了很多资料,也看了多开源库,但不是bug多就是库不维护.后来在GitHub上找到一个很棒的轮播图–BannerViewPager库推荐个大家 ...

  9. android github 评分控件_「开源」Arcgis for Android测量工具更新至V1.9,新增绘制控件...

    开源地址:https://github.com/roomanl/ArcgisTool 封装Arcgis Runtime for Android 100.6.0地图基本操作. 包括:测量工具控件及测量接 ...

  10. android 最新开源框架,Android酷炫实用的开源框架(UI框架)

    前言 忙碌的工作终于可以停息一段时间了,最近突然有一个想法,就是自己写一个app,所以找了一些合适开源控件,这样更加省时,再此分享给大家,希望能对大家有帮助,此博文介绍的都是UI上面的框架,接下来会有 ...

最新文章

  1. C语言学习笔记--预编译/宏定义/数组/参数传递/函数指针
  2. Docker 容器启动失败日志分析方法,启动sonic容器实例simple时未报错运行一会又停止的问题排查实例演示
  3. html中如何实现放大动画,CSS3实现点击放大的动画实例
  4. Central Authentication Service
  5. boost::hana::trait用法的测试程序
  6. 活动安排问题--贪心算法
  7. Weblogic 数据源及连接池配置问题Warning! Connectivity to backend database not verified
  8. 【算法学习】图相关算法编程实现-深度优先遍历和广度优先遍历
  9. fortran基础知识1----循环
  10. 目标追踪-背景差算法
  11. 3d pdf reader android,3D PDF Reader
  12. boolean类型_10、typescript的高级类型
  13. python可以嵌在vba中吗_Jupyter Notebooks嵌入Excel并使用Python替代VBA宏
  14. JAVA--获取当前日期两个月之前的日期
  15. 夜店App不应该是SNS,而应该是O2O
  16. 胡灵 c语言,清华作业们男女主角现身
  17. 用Python分析《令人心动的offer2》的13万条弹幕,网友们都在吐槽什么?
  18. C#程序设计--任何一个自然数m的立方均可写成m个连续奇数之和
  19. 【C/C++】泛型栈
  20. 大连鸿蒙刺青怎么样,哪个部位纹身最“疼”?纹身师:敢在这三个地方纹身的,是真汉子...

热门文章

  1. recycleview横向展开_Android开发之基于RecycleView实现的头部悬浮控件
  2. 信息安全竞赛解决方案
  3. Mongodb学习(1)安装以及配置
  4. 回归分析中的评价方法
  5. 手机建站系统php,zzzcms免费开源建站系统含手机
  6. 粗读MD-UNET: Multi-input dilated U-shape neural network for segmentation of bladder cancer
  7. 如何使用互联网思维,解决流浪动物问题
  8. 电脑投屏到电视android,电脑怎么投屏到电视?看完这篇文章你就懂了
  9. FPT Software携手三井物产提升日本网络安全水平
  10. Python爬虫(5)