- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
所以我有一个流,比方说字母,我需要所有字母按正确的顺序将它们组合成一个词。一切正常,直到用户更改选项卡、最小化浏览器或切换应用程序 - 行为几乎与我使用 setTimeout()
相同 - 弄乱了订单,丢失了元素等。我试图实现我的目标是使用 bufferWhen()
、bufferToggle()
、takeUntil()
、publish()
和 connect()
但没有成功。我也考虑过使用 delayWhen
,但它已被弃用并且可能不适合,因为它会立即停止流。我应该使用哪些功能以及如何使用?这是我的代码:
export class MyComponent implements AfterViewInit {
private visibilityChange$ = fromEvent(document, 'visibilitychange').pipe(startWith('visible'), shareReplay({ refCount: true, bufferSize: 1 }));
private show$ = this.visibilityChange$.pipe(filter(() => document.visibilityState === 'visible'));
private hide$ = this.visibilityChange$.pipe(filter(() => document.visibilityState === 'hidden'));
public ngAfterViewInit() {
const lettersStream$ = zip( // add delay for each letter
from(['w', 'o', 'r', 'd']),
interval(1000))
// pause when hide$ fires, resume when show$
.pipe(map(([letter, delayTime]) => letter))
.subscribe(console.log);
}
}
我在 stackblitz 上做了一个演示 - 我想要的就是看到(在标签不活动时停止写作)如何写在屏幕上。
最佳答案
因为我在我的 RxJS Snake Game 中做了类似的暂停/取消暂停操作, 我会帮助你举个例子。
想法是有一个 interval(1000)
作为真实来源,这意味着一切都将基于它。因此,基于我们需要停止在可见性隐藏时发出事件并在可见性显示时继续发出事件这一事实,我们的目标变成了使此间隔可暂停。最后,为了让事情变得更简单,我们可以在可见性隐藏时停止收听源间隔,并在可见性显示到来时再次开始收听。现在让我们来看看具体的实现:
您也可以在 RxJS Pause Observable 上使用修改后的 StackBlitz 演示代码.
import { of, interval, fromEvent, timer, from, zip, never } from 'rxjs';
import { delayWhen, tap, withLatestFrom, concatMap, take, startWith, distinctUntilChanged, switchMap, shareReplay, filter, map, finalize } from 'rxjs/operators';
console.log('-------------------------------------- STARTING ----------------------------')
class MyComponent {
private visibilityChange$ = fromEvent(document, 'visibilitychange')
.pipe(
map(x => document.visibilityState),
startWith('visible'),
shareReplay(1)
);
private isVisible$ = this.visibilityChange$.pipe(
map(x => x === 'visible'),
distinctUntilChanged(),
);
constructor() {
const intervalTime = 1000;
const source$ = from('word or two'.split(''));
/** should remove these .pipe(
concatMap(ch => interval(intervalTime).pipe(map(_ => ch), take(1)))
);*/
const pausableInterval$ = this.isVisible$.pipe(
switchMap(visible => visible ? interval(intervalTime) : never()),
)
const lettersStream$ = zip(pausableInterval$, source$).pipe(
map(([tick, letter]) => letter),
).subscribe(letter => {
this.writeLetter(letter);
});
}
private writeLetter(letter: string) {
if (letter === ' ') letter = '\u00A0'; // fix for spaces
document.body.innerText += letter;
}
}
const component = new MyComponent();
这是来自 StackBlitz 的确切代码,我复制到这里是为了更好地为您解释。
现在让我们为您分解有趣的部分:
查看 visibilityChange$
和 isVisible$
。它们稍作修改,因此第一个发出基于 document.visibilityState
的字符串值 'visible'
或 'hidden'
。当 document.visibilityState
等于 'visible'
时,第二个发出 true。
查看source$
。它将发出一个字母,然后在 concatMap
和 interval
的帮助下等待 1 秒,并使用 take(1)
执行此过程,直到有文本中没有剩余字符。
看看pausableInterval$
。基于将根据 document.visibilityState
更改的 this.isVisible$
,我们的 pausableInterval$
将每秒发射项目或不会发射由于 never()
而导致的任何事情。
最后看看 lettersStream$
。在 zip()
的帮助下,我们将压缩 pausableInterval$
和 source$
,因此我们将从 source 中获取一个字母,从暂停间隔。如果 pausableInterval$
由于可见性变化而停止发射,zip 也会等待,因为它需要两个 Observable 一起发射才能将事件发送到订阅者。
关于angular - RxJS 6 页面不活动时暂停或缓冲可观察,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57020431/
我正在使用 MediaPlayer 在我的应用程序中播放在线 mp3 文件中的一些声音。 但是,即使在播放完成后,我也会在控制台中收到一行又一行的回调和缓冲。 10-24 08:08:48.467
我有一个简单的多边形。 dfr p = st_polygon(list(as.matrix(dfr))) > pbuf = st_buffer(p, .4) > plot(pbuf) > plot(
这可能又是一些愚蠢的问题,也许这确实是我所缺少的东西,但我很难让 glMultiDrawArrays 在 OpenGL4 中工作。 我发现了很多这样的解释: for (int i = 0; i #i
这仅仅是根据网络速度调整预缓冲内容量的问题吗?你是否在一开始就为此调整一次,每秒......? 或者它更复杂 - 对您的网络速度记录历史进行采样并取平均值/中值并对其进行调整? 最佳答案 您的第二段总
嗨,我正在使用 FFmpeg Autogen C#。当我使用 mkv 输出作为文件并使用 h264 rtsp 流作为输入时,一切正常。编解码器是 libx264 ffmpeg.avio_open(
我需要多次遍历几个文本文件的行。目前这是通过多个 with open("file.txt") as f: for line in f: # do something 虽然性能还
昨天给同学们写了一个xinetd小练习:做一个反向回显程序。 为了学习新东西,我尝试实现一个 Haskell 解决方案。琐碎的main = forever $ interact reverse不起作用
我正在阅读《实时渲染第三版》中的遮挡剔除部分,但我无法理解它是如何工作的。一些问题: “Z 金字塔”有何贡献?为什么我们需要多种分辨率的 Z 缓冲区?在书中,它的显示如下(左侧): 八叉树结构与用于一
我通过串行端口与设备通信。 我已成功获取 InputStream 并读取设备发送的内容。 但问题是,我根本不知道何时停止阅读并继续执行另一项任务。 这是简化的代码: inputStream = ser
我有以下代码: func (q *Queue) GetStreams(qi *QueueInfo) { channel := make(chan error, len(qi.AudioChun
在我调用 -play 之前,有没有办法让 MPMusicPlayerController 缓冲内容?还是在您设置队列时默认执行此操作? AVAudioPlayer 有 -prepareToPlay 方
我正在编写一个数据库 备份函数,从System.Diagnostics.Process 对象 读取StandardOutput (StreamReader) 属性。我已成功写入普通文件。 //This
我有一个 wpf 应用程序,其中所有 viewModel 都继承自实现 INotifyPropertyChanged 的类 NotifyPropertyChangeClass(见下文)。 我想限制
我需要类似于 withLatestFrom 的东西,对应于下图: ---------A-----------------B-- -1-2-3------4------5-6-7-8---- -----
有没有办法缓冲 OutputStream,在返回之前修改它?这是我的代码片段: public ServletOutputStream getOutputStream() throws IOExcept
目前我们有实现服务器通信协议(protocol)缓冲的需求。如果有人对此有任何意见,他们可以向我提供任何意见吗。 最佳答案 请查看以下 Protocol Buffer 链接。 http://code.
所以我目前正在开发一个 Java 应用程序,该应用程序应该将特定事件记录到数据库中。我希望每分钟最多有 15 到 20 次插入,基本上我想知道我是否应该为每个插入语句建立一个新连接,或者只要应用程序正
请考虑以下代码,包括两个线程 buffering_thread(用一条消息填充缓冲区指针)和 sending_thread(清空缓冲区): #include "msg.cpp" msg * buffe
是否可以在线播放由两个或多个视频文件组成的视频? 由于我原来的帖子不够清楚,这里有扩展的解释和问题。 我的站点托管在 Linux/Apache/PHP 服务器上。我有 FLV/F4V 格式的视频文件。
这是我用于缓冲和转换传入事件的代码: public Publisher> logs(String eventId) { ConnectableObservable connectableObs
我是一名优秀的程序员,十分优秀!