iOS app加固策略
http://www.cocoachina.com/ios/20170324/18955.html
RxAndroid和RxJava结合OkGo示例请求网络图片加载到不同ImageView
代码:
package zhangphil.app;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.util.Log;
import android.widget.ImageView;
import android.widget.TextView;
import com.lzy.okgo.OkGo;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.functions.Function;
import io.reactivex.observers.DisposableObserver;
import io.reactivex.schedulers.Schedulers;
import okhttp3.Response;
/**
* 本例使用RxAndroid和RxJava,结合Okgo,在一个最普遍的应用场景,
* 比如有两个ImageView,给每个ImageView请求给定的url,请求回Bitmap后,分别装载到相应的ImageView。
* 这种情况在实际的开发中十分常见,本利给出一个基本用法,由此可以举一反三变化出更多更复杂的用法。
*
*/
public class MainActivity extends Activity {
private final String TAG = String.valueOf(UUID.randomUUID());
private DisposableObserver<MyItem> mObserver = new DisposableObserver<MyItem>() {
@Override
public void onNext(MyItem item) {
item.image.setImageBitmap(item.bitmap);
item.text.setText(item.url);
}
@Override
public void onComplete() {
Log.d(TAG, "onComplete");
}
@Override
public void onError(Throwable e) {
Log.e(TAG, e.toString(), e);
}
};
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ImageView image1 = (ImageView) findViewById(R.id.image1);
ImageView image2 = (ImageView) findViewById(R.id.image2);
TextView text1 = (TextView) findViewById(R.id.text1);
TextView text2 = (TextView) findViewById(R.id.text2);
String url1 = "http://avatar.csdn.net/9/7/A/1_zhangphil.jpg";
String url2 = "http://avatar.csdn.net/9/7/A/2_zhangphil.jpg";
List<MyItem> lists = new ArrayList<>();
MyItem i1 = new MyItem();
i1.image = image1;
i1.url = url1;
i1.text = text1;
lists.add(i1);
MyItem i2 = new MyItem();
i2.image = image2;
i2.url = url2;
i2.text = text2;
lists.add(i2);
Observable mObservable = Observable
.just(lists)
.flatMap(function)
.map(getBitmap)
.subscribeOn(Schedulers.io()) //执行任务的线程
.observeOn(AndroidSchedulers.mainThread()); //回调发生的线程
//建立订阅关系
mObservable.subscribe(mObserver);
//mObservable.subscribe(mConsumer);
}
private class MyItem {
public ImageView image;
public Bitmap bitmap;
public TextView text;
public String url;
}
private Function<MyItem, MyItem> getBitmap = new Function<MyItem, MyItem>() {
@Override
public MyItem apply(MyItem item) throws Exception {
//同步方法返回观察者需要的数据结果
//在这里处理线程化的操作
Response response = OkGo.get(item.url).tag(TAG).execute();
try {
if (response.isSuccessful()) {
byte[] bytes = response.body().bytes();
item.bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
}
} catch (Exception e) {
e.printStackTrace();
}
return item;
}
};
// 设置映射函数
private Function<List<MyItem>, Observable<MyItem>> function = new Function<List<MyItem>, Observable<MyItem>>() {
@Override
public Observable<MyItem> apply(List<MyItem> lists) {
MyItem[] items = new MyItem[lists.size()];
for (int i = 0; i < lists.size(); i++) {
items[i] = lists.get(i);
}
return Observable.fromArray(items);
}
};
//如果只是接受处理结果,那么可以不用DisposableObserver,而用Consumer(消费)
// private Consumer mConsumer = new Consumer<Bitmap>() {
// @Override
// public void accept(Bitmap bmp) throws Exception {
// image.setImageBitmap(bmp);
// }
// };
@Override
protected void onDestroy() {
super.onDestroy();
OkGo.getInstance().cancelTag(TAG);
}
}
布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<ImageView
android:id="@+id/image1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal" />
<TextView
android:id="@+id/text1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textColor="@android:color/black" />
<View
android:layout_width="match_parent"
android:layout_height="50dp"
android:background="@android:color/holo_orange_light" />
<ImageView
android:id="@+id/image2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal" />
<TextView
android:id="@+id/text2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textColor="@android:color/black" />
</LinearLayout>
不要忘记在build.gradle配置:
compile 'io.reactivex.rxjava2:rxandroid:2.0.1'
compile 'io.reactivex.rxjava2:rxjava:2.0.1'
compile 'com.lzy.net:okgo:+' //版本号使用 + 可以自动引用最新版
compile 'com.lzy.net:okserver:+' //版本号使用 + 可以自动引用最新版
运行结果如图:
致谢:
冯祖学对本文有重大贡献!
微信关注我们
转载内容版权归作者及来源网站所有!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。
为解决软件依赖安装时官方源访问速度慢的问题,腾讯云为一些软件搭建了缓存服务。您可以通过使用腾讯云软件源站来提升依赖包的安装速度。为了方便用户自由搭建服务架构,目前腾讯云软件源站支持公网访问和内网访问。
Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。
Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。