ex
Fork of mbed-os-example-mbed5-blinky by
Diff: dcs-sdk-java-master/app/src/main/java/com/baidu/duer/dcs/devicemodule/audioplayer/report/AudioPlayerProgressReporter.java
- Revision:
- 45:2aa9f933c8d2
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/dcs-sdk-java-master/app/src/main/java/com/baidu/duer/dcs/devicemodule/audioplayer/report/AudioPlayerProgressReporter.java Tue Jul 18 16:34:48 2017 +0800
@@ -0,0 +1,130 @@
+/*
+ * Copyright (c) 2017 Baidu, Inc. All Rights Reserved.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.baidu.duer.dcs.devicemodule.audioplayer.report;
+
+import com.baidu.duer.dcs.devicemodule.audioplayer.message.PlayPayload;
+
+import java.util.concurrent.Executors;
+import java.util.concurrent.ScheduledExecutorService;
+import java.util.concurrent.ScheduledFuture;
+import java.util.concurrent.TimeUnit;
+
+/**
+ * 当服务器返回Play指令有progressReportDelayInMilliseconds,
+ * <p>
+ * ProgressReportDelayElapsed和ProgressReportIntervalElapsed事件的上报
+ * <p>
+ * Created by guxiuzhong@baidu.com on 2017/5/22.
+ */
+public class AudioPlayerProgressReporter {
+ private final ScheduledExecutorService eventScheduler = Executors.newScheduledThreadPool(1);
+ private ScheduledFuture<?> progressReportDelayFuture;
+ private ScheduledFuture<?> progressReportIntervalFuture;
+ private final Runnable progressReportDelayRunnable;
+ private final Runnable progressReportIntervalRunnable;
+ private final AudioPlayerTimer audioPlayerTimer;
+ private long progressReportDelay;
+ private long progressReportInterval;
+ private boolean isSetup;
+
+ public AudioPlayerProgressReporter(Runnable progressReportDelayRunnable,
+ Runnable progressReportIntervalRunnable,
+ AudioPlayerTimer audioPlayerTimer) {
+ if (progressReportDelayRunnable == null
+ || progressReportIntervalRunnable == null
+ || audioPlayerTimer == null) {
+ throw new IllegalArgumentException("All arguments must be provided.");
+ }
+ this.progressReportDelayRunnable = progressReportDelayRunnable;
+ this.progressReportIntervalRunnable = progressReportIntervalRunnable;
+ this.audioPlayerTimer = audioPlayerTimer;
+ this.isSetup = false;
+ }
+
+ public synchronized void setup(PlayPayload.ProgressReport progressReport) {
+ if (progressReport == null) {
+ String errorMessage = "ProgressReport must not be null.";
+ throw new IllegalArgumentException(errorMessage);
+ }
+ if (isSetup) {
+ String errorMessage = "AudioPlayerProgressReporter has already been setup. "
+ + "Please disable it before setting it up again.";
+ throw new IllegalStateException(errorMessage);
+ }
+
+ cancelEvents();
+ progressReportDelay = progressReport.progressReportDelayInMilliseconds;
+ progressReportInterval = progressReport.progressReportIntervalInMilliseconds;
+ isSetup = true;
+ }
+
+ public synchronized void disable() {
+ isSetup = false;
+ cancelEvents();
+ progressReportDelay = 0;
+ progressReportInterval = 0;
+ }
+
+ public synchronized void start() {
+ cancelEvents();
+
+ if (!isSetup) {
+ String errorMessage = "AudioPlayerProgressReporter cannot be started "
+ + "because it has not been setup yet.";
+ throw new IllegalStateException(errorMessage);
+ }
+
+ long currentOffsetIntoTrack = audioPlayerTimer.getOffsetInMilliseconds();
+
+ long timeUntilDelayReport = progressReportDelay - currentOffsetIntoTrack;
+ if (timeUntilDelayReport > 0) {
+ scheduleDelayEvent(timeUntilDelayReport);
+ }
+
+ long timeUntilIntervalReport = progressReportInterval == 0 ? 0 :
+ progressReportInterval - (currentOffsetIntoTrack % progressReportInterval);
+ if (timeUntilIntervalReport > 0) {
+ scheduleIntervalEvent(timeUntilIntervalReport, progressReportInterval);
+ }
+ }
+
+ public synchronized void stop() {
+ cancelEvents();
+ }
+
+ public synchronized boolean isSetup() {
+ return isSetup;
+ }
+
+ private void scheduleDelayEvent(long delay) {
+ progressReportDelayFuture = eventScheduler.schedule(progressReportDelayRunnable, delay,
+ TimeUnit.MILLISECONDS);
+ }
+
+ private void scheduleIntervalEvent(long delay, long interval) {
+ progressReportIntervalFuture = eventScheduler.scheduleAtFixedRate(
+ progressReportIntervalRunnable, delay, interval, TimeUnit.MILLISECONDS);
+ }
+
+ private void cancelEvents() {
+ if (progressReportDelayFuture != null && !progressReportDelayFuture.isDone()) {
+ progressReportDelayFuture.cancel(false);
+ }
+ if (progressReportIntervalFuture != null && !progressReportIntervalFuture.isDone()) {
+ progressReportIntervalFuture.cancel(false);
+ }
+ }
+}
