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