当前位置: 编程技术>移动开发
本页文章导读:
▪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
最新技术文章: