私はアンドロイド UPnP/DLNA アプリに取り組んでいます。メディア サーバーからレンダラーにファイルをストリーミングできるコントロール ポイントが動作しています。再生中にファイルを一時停止/再生して停止することはできますが、シークバーをコントロール ポイントに統合して再生中のファイルの進行状況を表示し、シークバーを操作できるようにする方法がわかりません。Cling Java ライブラリを使用してアプリを作成しています。誰かが私を助けることができる例を持っていれば、本当に感謝しています.
ありがとう
SubscriptionCallback の例を実装して、LastChange に登録しようとしました
SubscriptionCallback callback = new SubscriptionCallback(service, 600) { // Timeout in seconds
public void established(GENASubscription sub) {
System.out.println("Established: " + sub.getSubscriptionId());
}
@Override
public void failed(GENASubscription sub, UpnpResponse response, Exception ex) {
System.err.println(
createDefaultFailureMessage(response, ex)
);
}
@Override
public void ended(GENASubscription sub, CancelReason reason, UpnpResponse response) {
// Reason should be null, or it didn't end regularly
}
public void eventReceived(GENASubscription sub) {
System.out.println("Event: " + sub.getCurrentSequence().getValue());
try {
lastChange = new LastChange(
new AVTransportLastChangeParser(),
sub.getCurrentValues().get("LastChange").toString()
);
} catch (Exception ex) {
log.warning("Error parsing LastChange event content: " + ex);
return;
}
Map<String, StateVariableValue> values = sub.getCurrentValues();
StateVariableValue status = values.get("Status");
System.out.println("Status is: " + status.toString());
}
public void eventsMissed(GENASubscription sub, int numberOfMissedEvents) {
System.out.println("Missed events: " + numberOfMissedEvents);
}
@Override
protected void failed(GENASubscription arg0,
UpnpResponse arg1, Exception arg2, String arg3) {
}
};
upnpService.getControlPoint().execute(callback);
次に、現在再生中のトラックの長さを取得しようとします。
System.out.println("Duration: "+lastChange.getEventedValue(0, AVTransportVariable.CurrentTrackDuration.class).getValue());
しかし、これは NullPointerException を返します。
何か案は???????
** * ** * ** * ** *更新* ** * ** * ** * *
Seek() を実装しようとしましたが、成功していません。
シークバーとリスナーがありますが、シークバーを新しい位置にドラッグすると失敗し続けます。
seekbar.setOnSeekBarChangeListener(new OnSeekBarChangeListener()
{
@Override
public void onProgressChanged(SeekBar arg0, int arg1, boolean arg2)
{
Log.i("SEEKTIME", "time:" + arg1);
upnpService.getControlPoint().execute(new Seek(service, SeekMode.REL_TIME, arg0.toString())
{
@Override
public void success(ActionInvocation invocation)
{
//super.success(invocation);
Log.i("SEEKSUCCESS", "success seek");
}
@Override
public void failure(ActionInvocation arg0, UpnpResponse arg1, String arg2)
{
Log.i("SEEKFAIL", "fail seek");
}
});
}
これが失敗する理由についての提案