- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 2 个 ListView 。它包含文本项。我想将文本项目从左侧列表拖放到右侧列表。这一点我没有问题。另外,我有一个 Observable,它发出 KalturaVideo 对象。这是我如何获得这个可观察的代码:此函数获取已添加到右侧 ListView 中的对象的 id,如果对象 id 等于 targetList 中的某个 id,则从结果中排除对象:
private Observable<KalturaVideo> getSourceListObservalbe(String kalturaPlaylistId){
Observable<String[]> targetIdList = Observable.just(targetList)
.map((List<KalturaVideo> kalturaVideos) -> {
if(kalturaVideos == null || kalturaVideos.isEmpty()){
return new String[]{""};
}
String[] result = new String[kalturaVideos.size()];
int index = 0;
for (KalturaVideo item : kalturaVideos) {
result[index] = item.getId();
}
return result;
});
return Observable.combineLatest(
targetIdList,
KalturaVideoRetriver.getVideoList(BuildPlaylistStep2Activity.this, kalturaPlaylistId),
(String[] idListOfTarget, KalturaVideo kalturaVideo) -> {
for (String item :idListOfTarget){
if(item.equals(kalturaVideo.getId())){
return null;
}
}
return kalturaVideo;
})
.doOnError(throwable -> {
int i =0;
i++;
throwable.printStackTrace();
})
.filter(kalturaVideo -> {
return kalturaVideo != null;
});
}
这是视频检索器的代码:
public class KalturaVideoRetriver {
public static final String KALTURA_NEW_PLAYLIST_ID = "NEW_PLAYLIST";
public static Observable<KalturaVideo> getVideoList(Context context, String kalturaPlaylistId){
return Observable.create(new Observable.OnSubscribe<KalturaVideo>() {
@Override
public void call(Subscriber<? super KalturaVideo> subscriber) {
getKalturaPlaylistContentObservable(kalturaPlaylistId, context)
.flatMap(new Func1<String[], Observable<?>>() {
@Override
public Observable<?> call(String[] videoIdList) {
return getKalturaVideoListObservable(context, videoIdList)
.doOnNext(kalturaVideo -> {
subscriber.onNext(kalturaVideo);
})
.doOnCompleted(() -> subscriber.onCompleted());
}
})
.subscribe();
}
});
}
private static Observable<KalturaVideo> getKalturaVideoListObservable(Context context, String[] kalturaVideoIdArray){
return Observable.create(new Observable.OnSubscribe<KalturaVideo>() {
@Override
public void call(Subscriber<? super KalturaVideo> subscriber) {
Cursor query;
List<KalturaVideo> result = new ArrayList<>();
if(kalturaVideoIdArray == null || kalturaVideoIdArray.length == 0) {
query = context.getContentResolver().query(KalturaVideoColumns.CONTENT_URI, null, null, null, null);
}else {
KalturaVideoSelection where = new KalturaVideoSelection();
where.kalturaIdLike(kalturaVideoIdArray);
query = context.getContentResolver().query(
KalturaVideoColumns.CONTENT_URI,
null,
where.sel(),
where.args(),
null);
}
if(!query.moveToFirst()){
query.close();
subscriber.onCompleted();
}
KalturaVideoCursor cursor = new KalturaVideoCursor(query);
do{
KalturaVideo video = new KalturaVideo();
video.setId(cursor.getKalturaId());
video.setName(cursor.getName());
video.setDescription(cursor.getDescription());
video.setCategories(cursor.getCategories());
video.setCategoriesIds(cursor.getCategoriesIds());
video.setDownloadUrl(cursor.getDownloadUrl());
video.setThumbnailUrl(cursor.getThumbnailUrl());
video.setDataUrl(cursor.getDataUrl());
video.setDuration(cursor.getDuration());
subscriber.onNext(video);
}while (cursor.moveToNext());
query.close();
subscriber.onCompleted();
}
});
}
private static Observable<String[]> getKalturaPlaylistContentObservable(String kalturaPlaylistId, Context context){
return Observable.create(new Observable.OnSubscribe<String[]>() {
@Override
public void call(Subscriber<? super String[]> subscriber) {
if(kalturaPlaylistId.equals(KALTURA_NEW_PLAYLIST_ID)){
subscriber.onNext(new String[]{});
subscriber.onCompleted();
return;
}
KalturaPlaylistContentSelection where = new KalturaPlaylistContentSelection();
where.playlistId(kalturaPlaylistId);
Cursor query = context.getContentResolver().query(
KalturaPlaylistContentColumns.CONTENT_URI,
null,
where.sel(),
where.args(),
null
);
if(!query.moveToFirst()){
subscriber.onNext(new String[]{});
query.close();
subscriber.onCompleted();
return;
}
KalturaPlaylistContentCursor cursor = new KalturaPlaylistContentCursor(query);
String[] result = new String[query.getCount()];
int index = 0;
do{
result[index] = cursor.getKalturaVideoId();
index++;
}while (query.moveToNext());
query.close();
subscriber.onNext(result);
subscriber.onCompleted();
}
});
}
}
首先,在检索器中,我通过播放列表 ID 获取视频 ID。如果 PlaylistId 为空 - 我会获取所有存储在我的数据库中的视频 ID。之后,我通过 id 从数据库获取所有视频,这是我在上一步中获取的。
这是函数,它可以帮助我获取所有视频并显示它:
private Observable<KalturaVideo> fillLists(){
return getSourceListObservalbe(KalturaVideoRetriver.KALTURA_NEW_PLAYLIST_ID)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.doOnError(throwable -> {
Log.e("TAG", throwable.getCause().toString());
})
.doOnNext(kalturaVideo -> {
sourceList.add(kalturaVideo);
})
.doOnCompleted(() -> {
viewHolder.sourceListView.setAdapter(new BuildPlaylistContentAdapter(
BuildPlaylistStep2Activity.this,
-1,
sourceList));
viewHolder.sourceListView.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
@Override
public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
KalturaVideo video = (KalturaVideo) view.getTag();
ClipData data = ClipData.newPlainText("kalturaVideoId", video.getId());
View.DragShadowBuilder shadowBuilder = new View.DragShadowBuilder(view);
view.startDrag(data, shadowBuilder, view, 0);
view.setVisibility(View.INVISIBLE);
return false;
}
});
viewHolder.targetListView.setAdapter(new BuildPlaylistContentAdapter(
BuildPlaylistStep2Activity.this,
-1,
targetList
));
});
}
这是我的订阅方式:
subscription = fillLists().subscribe();
这是我在拖放后尝试更新 2 个列表的方法:
targetList.add(video);
sourceList.clear();
fillLists().subscribe();
其中视频 - 是与 View 相关的视频,已删除到新列表。
所以,当我第一次将 View 放到另一个列表时,它工作得很好。但是当我第二次删除时,我在 doOnError 方法中得到了这个堆栈跟踪:
04-20 18:46:02.072 8015-8083/com.mediamanagment.app W/System.err﹕ java.lang.NullPointerException 04-20 18:46:02.072
8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.activity.BuildPlaylistStep2Activity.lambda$getSourceListObservalbe$3(BuildPlaylistStep2Activity.java:106) 04-20 18:46:02.072 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.activity.BuildPlaylistStep2Activity.access$lambda$1(BuildPlaylistStep2Activity.java) 04-20 18:46:02.072 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.activity.BuildPlaylistStep2Activity$$Lambda$2.call(Unknown Source) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.functions.Functions$3.call(Functions.java:76) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorCombineLatest$Collector.next(OperatorCombineLatest.java:157) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorCombineLatest$SourceSubscriber.onNext(OperatorCombineLatest.java:218) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$1$1.lambda$call$13(KalturaVideoRetriver.java:36) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$1$1.access$lambda$0(KalturaVideoRetriver.java) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$1$1$$Lambda$1.call(Unknown Source) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$12.onNext(Observable.java:3682) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorDoOnEach$1.onNext(OperatorDoOnEach.java:61) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$2.call(KalturaVideoRetriver.java:80) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$2.call(KalturaVideoRetriver.java:47) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable.unsafeSubscribe(Observable.java:6110) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorMerge$1.onNext(OperatorMerge.java:66) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorMerge$1.onNext(OperatorMerge.java:43) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorMap$1.onNext(OperatorMap.java:54) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$3.call(KalturaVideoRetriver.java:93) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$3.call(KalturaVideoRetriver.java:89) 04-20 18:46:02.080 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.080
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.088
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.088
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable.subscribe(Observable.java:6177) 04-20 18:46:02.088
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable.subscribe(Observable.java:5842) 04-20 18:46:02.088
8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$1.call(KalturaVideoRetriver.java:41) 04-20 18:46:02.088 8015-8083/com.mediamanagment.app W/System.err﹕ at com.mediamanagment.app.retrivers.KalturaVideoRetriver$1.call(KalturaVideoRetriver.java:27) 04-20 18:46:02.088 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable.unsafeSubscribe(Observable.java:6110) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorCombineLatest.call(OperatorCombineLatest.java:87) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorCombineLatest.call(OperatorCombineLatest.java:40) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.095
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.095
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:153) 04-20 18:46:02.095
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable$2.call(Observable.java:149) 04-20 18:46:02.095
8015-8083/com.mediamanagment.app W/System.err﹕ at rx.Observable.unsafeSubscribe(Observable.java:6110) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.operators.OperatorSubscribeOn$1$1.call(OperatorSubscribeOn.java:60) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at rx.schedulers.NewThreadScheduler$NewThreadWorker$ScheduledAction.run(NewThreadScheduler.java:141) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:390) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.FutureTask.run(FutureTask.java:234) 04-20 18:46:02.095 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:153) 04-20 18:46:02.103 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:267) 04-20 18:46:02.103 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080) 04-20 18:46:02.103 8015-8083/com.mediamanagment.app W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573) 04-20 18:46:02.103 8015-8083/com.mediamanagment.app W/System.err﹕ at java.lang.Thread.run(Thread.java:856)
没有返回任何视频
最佳答案
这段代码中出现了 NullPointerException
Log.e("TAG", throwable.getCause().toString());
我认为您的异常没有原因,因此 toString
调用抛出 NPE (NullPointerException)
将您的代码替换为
Log.e("TAG", throwable.getCause());
应该可以解决这个问题
但是您的代码非常复杂,某些部分可以用不同的方式编写。其他一些是 buggy 。
例如:
错误
.doOnError(throwable -> {
int i =0;
i++;
throwable.printStackTrace();
})
i
将始终等于 0(或 i++
之后为 1)。是自愿的吗?
错误代码
public static Observable<KalturaVideo> getVideoList(Context context, String kalturaPlaylistId){
return Observable.create(new Observable.OnSubscribe<KalturaVideo>() {
@Override
public void call(Subscriber<? super KalturaVideo> subscriber) {
getKalturaPlaylistContentObservable(kalturaPlaylistId, context)
.flatMap(new Func1<String[], Observable<?>>() {
@Override
public Observable<?> call(String[] videoIdList) {
return getKalturaVideoListObservable(context, videoIdList)
.doOnNext(kalturaVideo -> {
subscriber.onNext(kalturaVideo);
})
.doOnCompleted(() -> subscriber.onCompleted());
}
})
.subscribe();
}
});
}
不要在 Observable 中使用 Observable。只需改造第一个即可
public static Observable<KalturaVideo> getVideoList(Context context, String kalturaPlaylistId){
return getKalturaPlaylistContentObservable(kalturaPlaylistId, context).flatMap((String[] videoIdList) -> getKalturaVideoListObservable(context, videoIdList));
}
复杂代码
Observable<String[]> targetIdList = Observable.just(targetList)
.map((List<KalturaVideo> kalturaVideos) -> {
if(kalturaVideos == null || kalturaVideos.isEmpty()){
return new String[]{""};
}
String[] result = new String[kalturaVideos.size()];
int index = 0;
for (KalturaVideo item : kalturaVideos) {
result[index] = item.getId();
}
return result;
});
您尝试重写 Rx 本身已经可以执行的代码。
Observable<String[]> targetIdList = Observable.just(targetList)
.flatMapIterable(videos -> videos)
.map(video -> video.getId())
.toList()
.map(l -> l.toArray(new String[]));
关于java - RxJava 从 Observable 更新数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29751192/
我正在进行 2 个 RX 调用,这些调用相互嵌套且相互依赖。服务器存在问题(由于各种原因目前无法解决),该问题在第二个嵌套调用中返回错误。 在这个问题得到解决之前,我需要确保如果第二次调用返回错误,则
这个问题在这里已经有了答案: How to resolve Duplicate files copied in APK META-INF/rxjava.properties (8 个答案) 关闭 5
我正在尝试将此 RxJava1 代码转换为 RxJava2 public static Observable listFolder(Path dir, String glob) { retur
这个问题在这里已经有了答案: RxJava 1 and RxJava 2 in the same project [duplicate] (1 个回答) How to resolve Duplica
有显示项目的RecyclerViewAdapter(该项目已经映射到数据库中)。 RecyclerViewAdapter 包含对 Presenter 的引用以加载项目。它还包含带有项目 ID 的 Ar
我想弄清楚如何在 Android 中使用 RxJava 将 Realm 对象保存在 Realm 中。到目前为止,结合所有这些的所有示例都是如何从 Realm 读取数据的。我想在 android 中使用
我在日志中收到此错误: Caused by java.lang.ClassCastException: java.net.UnknownHostException cannot be cast to
我有一个 API 服务类,其方法返回 Retrofit 提供的调用。 最近,Rx2Java 引入了 Single,所以我想将 Call 更改为 Single,但我不想更改逻辑。 例如 : 类接口(in
如何使用运算符让我始终获得以前和当前的值?如果可能的话,我想避免在管道外创建状态。 - time -> 1 2 3 4 | | | | Op
我正在努力实现以下目标。我加载了一个对象列表,我想获取稍后放入列表中的值。 首先,我使用 flatmap 将所有值收集到一个数组中(按山顺序),然后当一切完成后,我填充一个适配器。 我无法做的是每
是否可以选择使用 timeout 的变体不发射 Throwable ? 我要 complete事件发出。 最佳答案 您不需要使用 onErrorResumeNext 映射错误。您可以使用以下方法提供备
我们可以在 C# Rx 中异步执行一些代码,如下所示,使用 Observable.Start()。我想知道 RxJava 中的等价物是什么。 void Main() { AddTwoNum
问题:我有一个用户可以输入查询字符串的功能,我制作了 2 个可观察对象,一个用于查询我的本地数据库,另一个用于从 API 获取结果。这两个操作必须并行运行。我需要尽快显示来自数据库的结果,当 API
我正在尝试在 MVVM 中实现 ViewModel,将可观察对象作为“输入流”提供,将观察者作为“输出流”提供以供 View 绑定(bind)。 如果 getUser() 调用成功,下面的代码似乎可以
出于某种原因,我有时想使用 RxOperators 而不是普通的 java 方式来转换数据结构,因为它越来越干净。例如: Observable.from(listOfStrings) .filter(
我是 RxJava 新手,我需要以异步方式使用 Observable 功能。 我还需要使用超时:在我的示例中,我希望每个进程在 1 秒或更短的时间内结束。 这是我现在所做的: public stati
我正在尝试在网络请求期间在UI中显示进度条至少3秒钟。 此答案中描述的相同方法似乎不适用于Single。 RxJava Observable minimum execution time Single
我有一个可观察的(很热),它通过系统进程执行操作,并且我希望也运行一个间隔,直到该进程可观察达到 onComplete。 我看到区间运算符:http://reactivex.io/documentat
好吧,我是 RxJava2 的新手(嗯,我也不了解 RxJava),并且正在尝试使用 RxJava2 和 MVP 结构开发 Android 应用程序。 在该应用程序中,我正在对使用监听器的库进行异步调
如何将单个流拆分为单独的单个流,这样就可以执行以下操作而无需两次计算getUserId()? // getUserId() returns Single getUserId().flatMap { g
我是一名优秀的程序员,十分优秀!