优秀的开源框架学习-创新互联

ButterKnife基本使用 http://www.cnblogs.com/mengdd/archive/2015/06/23/4595973.html

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名申请虚拟主机、营销软件、网站建设、容县网站维护、网站推广。

Android SlidingMenu 使用详解

http://blog.csdn.net/lmj623565791/article/details/36677279

ImageLoader的源码分析:

这个库封装的层次实在是太多了!!!可以借鉴作者是怎么封装类的!!!

DisplayImageOptions  Builder   配置一些参数

ImageLoaderEngine       引擎类

ProcessAndDisplayImageTask

ImageLoadingInfo        存储一些下载相关的信息

。。。

从ImageLoader.getInstance().displayImage这个方法追溯,这个方法可以选传url,p_w_picpath,也可以传

入参数和进度监听者。

1)ImageLoader的实例化采用单例设计模式

2)ImageLoader的初始化init方法会初始化引擎ImageLoaderEngine,并传入DisplayImageOptions参数

 》ImageLoaderEngine封装了一些线程池的操作

 》这个类里还用到FlushedInputStream这个类,FlushedInputStream会避免个别的错误Issue 6066: BitmapFactory.decodeStream() fails if InputStream.skip() does not skip fully

 》类中用同步Map来存储ImageView的缓存key值。

 》submit会将任务提交到线程池

3)判断uri为不为null,为null会将参数DisplayImageOptions中的默认图片设置给ImageView。

 同时会回调监听者的一些方法

 从参数DisplayImageOptions中得到大的图片尺寸

 根据url和图片的大尺寸来生成缓存的key

 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

 大致的思路:

 》在Application里init

  初始化参数DisplayImageOptions并传递给ImageLoaderEngine类。

  ImageLoaderEngine主要是维护了一些线程池,对Runnable任务进行管理。

  任务主要是通过Handler来实现线程间的通讯。

 》在display里解析DisplayImageOptions封装的参数信息

 》判断对url==null作处理

 》获取key

 String memoryCacheKey = MemoryCacheUtils.generateKey(uri, targetSize);

 ++DisplayImageOptions.Builder在初始化build()的时候,如果用户没有设置某些参数,它会自动

 进行一些默认设置,通过DefaultConfigurationFactory这个类。

public ImageLoaderConfiguration build() {
			initEmptyFieldsWithDefaultValues();
			return new ImageLoaderConfiguration(this);
}

 ++initEmptyFieldsWithDefaultValues方法进行的一些主要的初始化操作:

 如diskCache、memoryCache、downloader等,很好地体现了面向对象的编程思想。

private void initEmptyFieldsWithDefaultValues() {
			if (taskExecutor == null) {
				taskExecutor = DefaultConfigurationFactory
						.createExecutor(threadPoolSize, threadPriority, tasksProcessingType);
			} else {
				customExecutor = true;
			}
			if (taskExecutorForCachedImages == null) {
				taskExecutorForCachedImages = DefaultConfigurationFactory
						.createExecutor(threadPoolSize, threadPriority, tasksProcessingType);
			} else {
				customExecutorForCachedImages = true;
			}
			if (diskCache == null) {
				if (diskCacheFileNameGenerator == null) {
					diskCacheFileNameGenerator = DefaultConfigurationFactory.createFileNameGenerator();
				}
				diskCache = DefaultConfigurationFactory
						.createDiskCache(context, diskCacheFileNameGenerator, diskCacheSize, diskCacheFileCount);
			}
			if (memoryCache == null) {
				memoryCache = DefaultConfigurationFactory.createMemoryCache(context, memoryCacheSize);
			}
			if (denyCacheImageMultipleSizesInMemory) {
				memoryCache = new FuzzyKeyMemoryCache(memoryCache, MemoryCacheUtils.createFuzzyKeyComparator());
			}
			if (downloader == null) {
				downloader = DefaultConfigurationFactory.createImageDownloader(context);
			}
			if (decoder == null) {
				decoder = DefaultConfigurationFactory.createImageDecoder(writeLogs);
			}
			if (defaultDisplayImageOptions == null) {
				defaultDisplayImageOptions = DisplayImageOptions.createSimple();
			}
		}
	}

 》根据key从缓存中获取Bitmap

 Bitmap bmp = configuration.memoryCache.get(memoryCacheKey);

 判断缓存中有没有得到Bitmap

 LoadAndDisplayImageTask,从网络上下载图片位于tryLoadBitmap()这个方法当中

 通过BaseImageDecoder这个类的decode方法下载网络图片,通过BaseImageDownloader获得输入流,

 网络请求采用的是HttpURLConnection。

Freco图片加载框架:

1.缓存

在5.0以下系统,Bitmap缓存位于ashmem,这样Bitmap对象的创建和释放将不会引发GC,更少的GC会使你的APP运行得更加流畅。

5.0及其以上系统,相比之下,内存管理有了很大改进,所以Bitmap缓存直接位于Java的heap上。

当应用在后台运行是,该内存会被清空。

2.渐进式JPEG图

Fresco 支持渐进式的网络JPEG图。在开始加载之后,图会从模糊到清晰渐渐呈现。

你可以设置一个清晰度标准,在未达到这个清晰度之前,会一直显示占位图。

渐进式JPEG图仅仅支持网络图。

3.渐进式JPEG图

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享标题:优秀的开源框架学习-创新互联
网页地址:http://scyanting.com/article/ddeegd.html