Ich arbeite seit einer Woche mit xuggle und habe eine Methode geschrieben, um einen zu bekommen Frame durch ein Video, aber wenn Video lang ist, benötigt diese Methode zu viel Zeit:
%Vor%Weißt du einen besseren Weg, dies zu tun?
Nun, nachdem ich nur Ihren Code gelesen habe, sehe ich einige Optimierungen, die gemacht werden können.
Wenn Sie die gesamte Datei einmal durchgelesen haben, erstellen Sie einen Index für byteoffsets und Sekunden. Dann kann die Funktion den Byteoffset von den angegebenen Sekunden nachsehen und Sie können das Video an diesem Offset dekodieren und den Rest Ihres Codes machen.
Eine andere Möglichkeit ist, Ihre Methode zu verwenden, indem Sie jedes Mal die gesamte Datei durchlesen, aber anstatt den ganzen resampler, newPic und den Java-Bildkonverter-Code aufzurufen, prüfen Sie, ob die Sekunden zuerst übereinstimmen. Wenn dies der Fall ist, konvertieren Sie das Bild in ein neues Bild, das angezeigt werden soll.
Also
%Vor% Verwenden Sie seekKeyFrame
-Option. Sie können diese Funktion verwenden, um zu jeder Zeit in der Videodatei zu suchen (die Zeit ist in Millisekunden).
Von dort aus verwenden Sie Ihre klassische while(container.readNextPacket(packet) >= 0)
-Methode zum Abrufen der Bilder in Dateien.
Hinweis: Es wird nicht versucht, die Zeit zu bestimmen, sondern die ungefähren Werte, so dass Sie immer noch die Pakete durchgehen müssen (aber natürlich viel weniger als vorher).