当前位置:  编程技术>移动开发
本页文章导读:
    ▪listview 图片异步加载 的兑现并缓存到内存 和本地sdcard 中        listview 图片异步加载 的实现并缓存到内存 和本地sdcard 中 package com.dodoyota.weicom.net; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.lang.ref.SoftReference; import java.net.UR.........
    ▪ 避免UITableViewCell重叠的解决办法        避免UITableViewCell重叠的解决方法 在IOS开发的时候经常会用到UITableView,而当TableView进行拖动的时候经常会导致Cell的重叠,解决方法, 1 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexP.........
    ▪ APIDemo惯用代码解析(持续更新)       APIDemo常用代码解析(持续更新) 1.关于Dialog     |--- com.example.android.apis.app/AlertDialogSamples.java     里面包含了Dialog的各种用法,有10种不同的Dialog实例。     |--- com.example.android.apis.app/FragmentD.........

[1]listview 图片异步加载 的兑现并缓存到内存 和本地sdcard 中
    来源: 互联网  发布时间: 2014-02-18
listview 图片异步加载 的实现并缓存到内存 和本地sdcard 中
package com.dodoyota.weicom.net;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.lang.ref.SoftReference;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import android.graphics.drawable.Drawable;
import android.os.Environment;
import android.os.Handler;
import android.util.Log;

import com.weibo.sdk.android.util.FormatTools;
import com.weibo.sdk.android.util.MD5Utils;

/**
 * 异步加载图片
 * @author 高元东
 * @mailto 466862016@qq.com
 * 2013-6-20 下午9:58:57
 */
public class AsyncImageLoader {
	
	public Map<String, SoftReference<Drawable>> imageCache = new HashMap<String, SoftReference<Drawable>>();
	private static  ExecutorService executorService = Executors.newFixedThreadPool(5);
	private final Handler handler = new Handler();
	
	
	/***
	 * 异步加载图片
	 * @mailto 466862016@qq.com
	 * 2013-6-20 下午10:01:34
	 * @param imageUrl
	 * @param callback
	 * @return
	 */
	public Drawable loadDrawable(final String imageUrl,
			final ImageCallback callback) {
		// 如果缓存过就从缓存中取出数据
		if (imageCache.containsKey(MD5Utils.encode(imageUrl))) {
			SoftReference<Drawable> softReference = imageCache.get(MD5Utils.encode(imageUrl));
			if (softReference.get() != null) {
				Log.i("imageloader", "从缓存中获取图片");
				return softReference.get();
			}
		}
		
		//sdcard 可用使用
		  if(this.checkSdcard()) {
			  Drawable drawable = null;
			  File dir = new File(Environment.getExternalStorageDirectory()+"/weicom");
			   if(!dir.exists()) {
				   dir.mkdir();
			   }
			   
			   File header = new File(dir, MD5Utils.encode(imageUrl));
			   if(header.exists()) {
				   FileInputStream fileInputStream = null;
				try {
					fileInputStream = new FileInputStream(header);
					//从sdcard 中取数据
					
					    drawable = Drawable.createFromStream(fileInputStream, "ayscimage");
					    Log.i("imageloader", "从sdcard获取图片");
					   if(!imageCache.containsKey(MD5Utils.encode(imageUrl))) {
						   //在sdcard 中取出的图片放在缓存中
						   imageCache.put(MD5Utils.encode(imageUrl), new SoftReference<Drawable>(drawable));
					   }
					   return drawable;
				} catch (Exception e) {
					e.printStackTrace();
				}
				   
			   }
			  
		  }
		// 缓存中没有图像,则从网络上取出数据,并将取出的数据缓存到内存中
		executorService.submit(new Runnable() {
			public void run() {
				try {
					final Drawable drawable = loadImageFromUrl(/blog_article/imageUrl/index.html); 
						
					imageCache.put(imageUrl, new SoftReference<Drawable>(
							drawable));
					 
					Log.i("imageloader", "将图片保存在缓存中");
					/***
					 * 保存在sdcard 中
					 */
					if(checkSdcard()) {
						 File dir = new File(Environment.getExternalStorageDirectory()+"/weicom");
						   if(!dir.exists()) {
							   
							   dir.mkdir();
						   }
						   
						   File header = new File(dir, MD5Utils.encode(imageUrl));
						   
						   
							   FileOutputStream fileOutputStream = new FileOutputStream(header);
							   FormatTools formatTools = FormatTools.getInstance();
							   byte[] by = formatTools.Drawable2Bytes(drawable);
							   fileOutputStream.write(by);
							   fileOutputStream.flush();
							   Log.i("imageloader", "将图片保存在sdcard ");
						  
					}

					handler.post(new Runnable() {
						public void run() {
							callback.imageLoaded(drawable);
						}
					});
				} catch (Exception e) {
					throw new RuntimeException(e);
				}
			}
		});
		return null;
	}
	
	
	
	/***
	 * 按照 url  从网络上获取 图片
	 * @mailto 466862016@qq.com
	 * 2013-6-20 下午10:00:40
	 * @param imageUrl
	 * @return
	 */
	protected Drawable loadImageFromUrl(/blog_article/String imageUrl/index.html) {
		try {
			Log.i("imageloader", "从网络中获取图片");
			return Drawable.createFromStream(new URL(imageUrl).openStream(),
					"iamgeSync");

		} catch (Exception e) {
			throw new RuntimeException(e);
		}
	}

	/***
	 * 检查sdcard 是否可用
	 * @mailto 466862016@qq.com
	 * 2013-6-20 下午10:08:18
	 * @return
	 */
	private boolean checkSdcard() {
		
		String status = Environment.getExternalStorageState();
		if(status.equals(Environment.MEDIA_MOUNTED)) {
			return true;
		}
		return false;
		
	}
	/***
	 * 对外开放的接口
	 * @author 高元东
	 * @mailto 466862016@qq.com
	 * 2013-6-20 下午10:00:03
	 */
	public interface ImageCallback {
			public void imageLoaded(Drawable imageDrawable);
		}
}

 


    
[2] 避免UITableViewCell重叠的解决办法
    来源: 互联网  发布时间: 2014-02-18
避免UITableViewCell重叠的解决方法

在IOS开发的时候经常会用到UITableView,而当TableView进行拖动的时候经常会导致Cell的重叠,解决方法,

1

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    static NSString *CellIdentifier = @"ToneBoxMusicStyleViewCell";
    
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    
    if (cell == nil) {
        NSArray *nib = [[NSBundle mainBundle]loadNibNamed:@"ToneBoxMusicStyleViewCell" owner:self options:nil];
        
        if ([nib count] > 0) {
            cell = self.styleViewCell;
        }
    }else{
        for (UIView *subView in cell.contentView.subviews)
        {
            [subView removeFromSuperview];
        }
    }
    return cell;
}

 

 

2

//构建tableView
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    UITableViewCell *cell= [tableView dequeueReusableCellWithIdentifier:@"TodoViewController"];
    cell.tag = 1;
    if(!cell){
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleValue1 reuseIdentifier:@"TodoViewController"]autorelease];        
        
    }else{
        while ([cell.contentView.subviews lastObject] != nil) {
            [(UIView *)[cell.contentView.subviews lastObject] removeFromSuperview];
        }
    }

 


    
[3] APIDemo惯用代码解析(持续更新)
    来源: 互联网  发布时间: 2014-02-18
APIDemo常用代码解析(持续更新)
1.关于Dialog
    |--- com.example.android.apis.app/AlertDialogSamples.java
    里面包含了Dialog的各种用法,有10种不同的Dialog实例。
    |--- com.example.android.apis.app/FragmentDialog.java
    使用DialogFragment来实现Dialog,可以使用onCreateView()来创建Dialog布局,也可以使用DialogFragment类的getDialog()方法,在里面可以使用之前创建Dialog的方法,返回一个Dialog。
    Android官方推荐使用DialogFragment。
 
2.关于Pregerence
    |--- com.example.android.apis.preference
    这个包里面介绍了Preference的用法,包括使用Code和XML(addPreferencesFromResource)两种方法来实现preference布局,使用setListFooter可以在底部添加一个布局(代码里面是添加一个Button在底部)
 
3.关于Service
    创建Servcie的方法有startService()和bindServcie()两种:由startService()创建的服务的目的只是服务的启动和终止,而bindServcie()创建的的服务是为了服务的远程控制(一般都会获得一个服务对象实例).
    |--- com.example.android.apis.app/LocalServcie.java
    由startService()创建的服务调用完onCreate()方法后,将继续调用onStartCommand()方法,该方法有返回值,可以通过该返回值来设置Servcie被强行关闭之后是否重新再启动    
    通过在代码里面添加Log,得到bindServcie()的执行流程:1.客户端请求连接服务bindServcie()----->2.在绑定的服务生成之后,Android会调用服务的onBind()回调方法,用来处理服务绑定,onBind()方法返回一个IBinder对象,用于与服务通信----->3.客户端的ServcieConnection对象的onServiceConnected(cn,IBinder)方法使用第2步传递的IBinder对象,调用服务端的getService()得到服务实例.
    |--- com.example.android.apis.app/RemoteServcie.java    
    AIDL是一种接口定义语言,用来约束两个进程之间的通信规则,供编译器生成代码,用来实现Android设备上两个进程间的通信。
    以ISecondary.aidl文件为例,Android会根据AIDL文件中定义的接口自动生成绑定远程服务所需要的代码,整个bindServcie()的执行流程如下:
    1.进程A调用bindServcie()请求连接RemoteService
    2.进程B在服务生成之后回调onBind()方法,生成用于处理Binder IPC的IBinder对象,并返回
    3.进程A调用回调方法onServiceConnected()方法,利用onBind()返回的IBinder,将其传递给IScondary.Stub.asInterface()函数,并使用它生成与RemoteService服务绑定在一起的服务代理对象ISeondary.Stub.Proxy,最后将其保存到mSecondaryService成员变量中。至此,RemoteService的ISecondary接口的绑定就完成了。
    4.进程A使用服务代理对象ISeondary.Stub.Proxy,调用RemoteService服务的getPid()代理方法
    5.Binder IPC:服务代理对象ISeondary.Stub.Proxy向服务Binder对象ISeondary.Stub传递Binder IPC数据
    6.进程B调用RemoteService服务的getPid() Stub方法,ISeondary.Stub服务Binder对象获取Binder IPC数据后,会调用RemoteService服务里面实现的getPid() Stub方法,将服务进程ID返回给进程A

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3