![]() |
Bass.dll Visualisierung => Latenz Problem
Hallo,
ich bin gerade dabei eine kleines Tool zu schreiben, dass einen das Spektrum von einem Eingangskanal (Wave, Line-In etc auswählbar) anzeigt. Es funktioniert soweit, dass er mir was anzeigt. Aber wenn ich Musik mit Winamp laufen hab ist liegt die Latenz (laut Stopuhr^^) bei ca 4 Sekunden O.O Ich könnte mir vorstellen, dass das an nem Buffer vonner bass.dll liegt hab ein bisal rumprobiert aber es wird nich besser. Aber es muss doch ne möglichkeit geben mit der Latenz auf einen Bereich runterkommt den man nicht, oder kaum, merkt. Weiß jemand Rat? Danke im Voraus & mfg Robin P.S.: So starte ich das ganze:
Delphi-Quellcode:
BASS_SetConfig(BASS_CONFIG_UPDATEPERIOD, 1);
BASS_Init(-1, 44100, BASS_DEVICE_LATENCY, Application.Handle, nil) BASS_SetConfig(BASS_CONFIG_BUFFER, 1); R_INIT := BASS_RecordInit(-1); R_CHAN := BASS_RecordStart(44100, 2, 0, nil, 0); |
Re: Bass.dll Visualisierung => Latenz Problem
Hi
hast du es schon mal mit dem recordproc versucht? Das sollte dein Problem lösen.
Delphi-Quellcode:
R_CHAN := BASS_RecordStart(44100, 2, MAKELONG(BASS_RECORD_PAUSE, 10), @recordproc, 0);
BASS_ChannelPlay(R_CHAN, true); The buffer length for recording channels.
Delphi-Quellcode:
BASS_SetConfig(
****BASS_CONFIG_REC_BUFFER, ****DWORD length PS. mit BASS_DEVICE_LATENCY in Bass_init braucht dein Programm länger zum starten. |
Re: Bass.dll Visualisierung => Latenz Problem
thx
ich habs jetzt erstmal ohne recordproc probiert und es läuft ganz gut. Ich bemerkte die latenz kaum noch.. geschätzt sind noch so 200 - 300ms (is aber schwer einzuschätzen^^)
Delphi-Quellcode:
BASS_SetConfig(BASS_CONFIG_REC_BUFFER, 0);
// Init Recording Device R_INIT := BASS_RecordInit(-1); R_CHAN := BASS_RecordStart(44100, 2, MAKELONG(BASS_RECORD_PAUSE, 1), nil, 0); |
Re: Bass.dll Visualisierung => Latenz Problem
Hi
das bringt dir gar nichts wen du die werte noch weiter runter setzt. Für BASS_CONFIG_REC_BUFFER . 1000 (Min), 5000 (Max) und für MAKELONG(BASS_RECORD_PAUSE, 1) ist das Minimum 10ms nicht 1, mit (BASS_CONFIG_REC_BUFFER / 2) setzt du das Maximum! Das steht aber alles in der docu. Zitat:
Zitat:
|
Re: Bass.dll Visualisierung => Latenz Problem
Hallo
//bass_setconfig(BASS_CONFIG_FLOATDSP,1); bass_setconfig(BASS_CONFIG_UPDATEPERIOD,5); bass_setconfig(BASS_CONFIG_BUFFER,35); sollte das latenzproblem minimieren. die in dem obigen programmierbeispiel benutzte updateperiode in 1 ist unzulaessig und wird damit ignoriert und automatisch auf default 100ms gesetzt. schaue mal in die bass.doc und du wirst merken ... updateperiod kleiner 5ms geht nicht. wichtig auch die reihenfolge der setconfigs. erst updateperiode und danach buffer. buffer kann auch nicht 1 gewaehlt werden. habe verschiedenste soundkarten probiert und buffer < 20 erwiesen sich meist als zu klein. du koenntest auch die buffergroesse mit BASS_GETINFO(info); BASS_SetConfig(BASS_CONFIG_BUFFER,info.minbuf); festlegen. natuerlich das definieren von "info" mit var info : bass_info; nicht vergessen. im grossen und ganzen sind buffergroessen 30..50 brauchbare werte. viel spass beim knobeln ... Frank |
Re: Bass.dll Visualisierung => Latenz Problem
Liste der Anhänge anzeigen (Anzahl: 2)
So jetzt siehts gut aus. Ihr könnt es euch ja mal angucken ;)
Danke für die Hilfe! |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:19 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz