Add video compression selector
This commit is contained in:
parent
fd165e5106
commit
fcccf545ba
|
@ -24,7 +24,8 @@ import eu.siacs.conversations.entities.Message;
|
||||||
import eu.siacs.conversations.persistance.FileBackend;
|
import eu.siacs.conversations.persistance.FileBackend;
|
||||||
import eu.siacs.conversations.ui.UiCallback;
|
import eu.siacs.conversations.ui.UiCallback;
|
||||||
import eu.siacs.conversations.utils.Android360pFormatStrategy;
|
import eu.siacs.conversations.utils.Android360pFormatStrategy;
|
||||||
import eu.siacs.conversations.utils.Android480pFormatStrategy;
|
import eu.siacs.conversations.utils.Android720pFormatStrategy;
|
||||||
|
import eu.siacs.conversations.utils.Android1080pFormatStrategy;
|
||||||
import eu.siacs.conversations.utils.MimeUtils;
|
import eu.siacs.conversations.utils.MimeUtils;
|
||||||
|
|
||||||
public class AttachFileToConversationRunnable implements Runnable, MediaTranscoder.Listener {
|
public class AttachFileToConversationRunnable implements Runnable, MediaTranscoder.Listener {
|
||||||
|
@ -91,8 +92,22 @@ public class AttachFileToConversationRunnable implements Runnable, MediaTranscod
|
||||||
mXmppConnectionService.startForcingForegroundNotification();
|
mXmppConnectionService.startForcingForegroundNotification();
|
||||||
message.setRelativeFilePath(message.getUuid() + ".mp4");
|
message.setRelativeFilePath(message.getUuid() + ".mp4");
|
||||||
final DownloadableFile file = mXmppConnectionService.getFileBackend().getFile(message);
|
final DownloadableFile file = mXmppConnectionService.getFileBackend().getFile(message);
|
||||||
final int runtime = mXmppConnectionService.getFileBackend().getMediaRuntime(uri);
|
final MediaFormatStrategy formatStrategy;
|
||||||
final MediaFormatStrategy formatStrategy = runtime >= 20000 ? new Android360pFormatStrategy() : new Android480pFormatStrategy();
|
final String compressVideo = mXmppConnectionService.getResources().getString(R.string.video_compression);
|
||||||
|
switch (compressVideo) {
|
||||||
|
case "720":
|
||||||
|
formatStrategy = new Android720pFormatStrategy();
|
||||||
|
Log.d(Config.LOGTAG,"WOOOMP 720 dar " + compressVideo);
|
||||||
|
break;
|
||||||
|
case "1080":
|
||||||
|
formatStrategy = new Android1080pFormatStrategy();
|
||||||
|
Log.d(Config.LOGTAG,"WOOOMP 1080 dar " + compressVideo);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
formatStrategy = new Android360pFormatStrategy();
|
||||||
|
Log.d(Config.LOGTAG,"WOOOMP 360 dar" + compressVideo);
|
||||||
|
break;
|
||||||
|
}
|
||||||
file.getParentFile().mkdirs();
|
file.getParentFile().mkdirs();
|
||||||
final ParcelFileDescriptor parcelFileDescriptor = mXmppConnectionService.getContentResolver().openFileDescriptor(uri, "r");
|
final ParcelFileDescriptor parcelFileDescriptor = mXmppConnectionService.getContentResolver().openFileDescriptor(uri, "r");
|
||||||
if (parcelFileDescriptor == null) {
|
if (parcelFileDescriptor == null) {
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
package eu.siacs.conversations.utils;
|
||||||
|
|
||||||
|
import android.media.MediaCodecInfo;
|
||||||
|
import android.media.MediaFormat;
|
||||||
|
import android.util.Log;
|
||||||
|
|
||||||
|
import net.ypresto.androidtranscoder.format.MediaFormatExtraConstants;
|
||||||
|
import net.ypresto.androidtranscoder.format.MediaFormatStrategy;
|
||||||
|
import net.ypresto.androidtranscoder.format.OutputFormatUnavailableException;
|
||||||
|
|
||||||
|
import eu.siacs.conversations.Config;
|
||||||
|
|
||||||
|
public class Android1080pFormatStrategy implements MediaFormatStrategy {
|
||||||
|
|
||||||
|
private static final int LONGER_LENGTH = 1920;
|
||||||
|
private static final int SHORTER_LENGTH = 1080;
|
||||||
|
private static final int DEFAULT_VIDEO_BITRATE = 4000 * 1000;
|
||||||
|
private static final int DEFAULT_AUDIO_BITRATE = 128 * 1000;
|
||||||
|
private final int mVideoBitrate;
|
||||||
|
private final int mAudioBitrate;
|
||||||
|
private final int mAudioChannels;
|
||||||
|
|
||||||
|
public Android1080pFormatStrategy() {
|
||||||
|
mVideoBitrate = DEFAULT_VIDEO_BITRATE;
|
||||||
|
mAudioBitrate = DEFAULT_AUDIO_BITRATE;
|
||||||
|
mAudioChannels = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public MediaFormat createVideoOutputFormat(MediaFormat inputFormat) {
|
||||||
|
int width = inputFormat.getInteger(MediaFormat.KEY_WIDTH);
|
||||||
|
int height = inputFormat.getInteger(MediaFormat.KEY_HEIGHT);
|
||||||
|
int longer, shorter, outWidth, outHeight;
|
||||||
|
if (width >= height) {
|
||||||
|
longer = width;
|
||||||
|
shorter = height;
|
||||||
|
outWidth = LONGER_LENGTH;
|
||||||
|
outHeight = SHORTER_LENGTH;
|
||||||
|
} else {
|
||||||
|
shorter = width;
|
||||||
|
longer = height;
|
||||||
|
outWidth = SHORTER_LENGTH;
|
||||||
|
outHeight = LONGER_LENGTH;
|
||||||
|
}
|
||||||
|
if (longer * 9 != shorter * 16) {
|
||||||
|
throw new OutputFormatUnavailableException("This video is not 16:9, and is not able to transcode. (" + width + "x" + height + ")");
|
||||||
|
}
|
||||||
|
if (shorter <= SHORTER_LENGTH) {
|
||||||
|
Log.d(Config.LOGTAG, "This video is less or equal to 1080p, pass-through. (" + width + "x" + height + ")");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
MediaFormat format = MediaFormat.createVideoFormat("video/avc", outWidth, outHeight);
|
||||||
|
// From Nexus 4 Camera in 720p
|
||||||
|
format.setInteger(MediaFormat.KEY_BIT_RATE, mVideoBitrate);
|
||||||
|
format.setInteger(MediaFormat.KEY_FRAME_RATE, 30);
|
||||||
|
format.setInteger(MediaFormat.KEY_I_FRAME_INTERVAL, 3);
|
||||||
|
format.setInteger(MediaFormat.KEY_COLOR_FORMAT, MediaCodecInfo.CodecCapabilities.COLOR_FormatSurface);
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public MediaFormat createAudioOutputFormat(MediaFormat inputFormat) {
|
||||||
|
final MediaFormat format = MediaFormat.createAudioFormat(MediaFormatExtraConstants.MIMETYPE_AUDIO_AAC, inputFormat.getInteger(MediaFormat.KEY_SAMPLE_RATE), mAudioChannels);
|
||||||
|
format.setInteger(MediaFormat.KEY_AAC_PROFILE, MediaCodecInfo.CodecProfileLevel.AACObjectLC);
|
||||||
|
format.setInteger(MediaFormat.KEY_BIT_RATE, mAudioBitrate);
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -10,17 +10,17 @@ import net.ypresto.androidtranscoder.format.OutputFormatUnavailableException;
|
||||||
|
|
||||||
import eu.siacs.conversations.Config;
|
import eu.siacs.conversations.Config;
|
||||||
|
|
||||||
public class Android480pFormatStrategy implements MediaFormatStrategy {
|
public class Android720pFormatStrategy implements MediaFormatStrategy {
|
||||||
|
|
||||||
private static final int LONGER_LENGTH = 854;
|
private static final int LONGER_LENGTH = 1280;
|
||||||
private static final int SHORTER_LENGTH = 480;
|
private static final int SHORTER_LENGTH = 720;
|
||||||
private static final int DEFAULT_VIDEO_BITRATE = 2000 * 1000; // 2000 kbit/s upper range of what YouTube recommends
|
private static final int DEFAULT_VIDEO_BITRATE = 2000 * 1000; // 2000 kbit/s upper range of what YouTube recommends
|
||||||
private static final int DEFAULT_AUDIO_BITRATE = 96 * 1000;
|
private static final int DEFAULT_AUDIO_BITRATE = 96 * 1000;
|
||||||
private final int mVideoBitrate;
|
private final int mVideoBitrate;
|
||||||
private final int mAudioBitrate;
|
private final int mAudioBitrate;
|
||||||
private final int mAudioChannels;
|
private final int mAudioChannels;
|
||||||
|
|
||||||
public Android480pFormatStrategy() {
|
public Android720pFormatStrategy() {
|
||||||
mVideoBitrate = DEFAULT_VIDEO_BITRATE;
|
mVideoBitrate = DEFAULT_VIDEO_BITRATE;
|
||||||
mAudioBitrate = DEFAULT_AUDIO_BITRATE;
|
mAudioBitrate = DEFAULT_AUDIO_BITRATE;
|
||||||
mAudioChannels = 2;
|
mAudioChannels = 2;
|
||||||
|
@ -46,7 +46,7 @@ public class Android480pFormatStrategy implements MediaFormatStrategy {
|
||||||
throw new OutputFormatUnavailableException("This video is not 16:9, and is not able to transcode. (" + width + "x" + height + ")");
|
throw new OutputFormatUnavailableException("This video is not 16:9, and is not able to transcode. (" + width + "x" + height + ")");
|
||||||
}
|
}
|
||||||
if (shorter <= SHORTER_LENGTH) {
|
if (shorter <= SHORTER_LENGTH) {
|
||||||
Log.d(Config.LOGTAG, "This video is less or equal to 360p, pass-through. (" + width + "x" + height + ")");
|
Log.d(Config.LOGTAG, "This video is less or equal to 720p, pass-through. (" + width + "x" + height + ")");
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
MediaFormat format = MediaFormat.createVideoFormat("video/avc", outWidth, outHeight);
|
MediaFormat format = MediaFormat.createVideoFormat("video/avc", outWidth, outHeight);
|
|
@ -112,4 +112,16 @@
|
||||||
<item>@string/medium</item>
|
<item>@string/medium</item>
|
||||||
<item>@string/large</item>
|
<item>@string/large</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
|
<string-array name="video_compression_values">
|
||||||
|
<item>360</item>
|
||||||
|
<item>720</item>
|
||||||
|
<item>1080</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
|
<string-array name="video_compression_entries">
|
||||||
|
<item>@string/video_360p</item>
|
||||||
|
<item>@string/video_720p</item>
|
||||||
|
<item>@string/video_1080p</item>
|
||||||
|
</string-array>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -42,4 +42,5 @@
|
||||||
<string name="default_font_size">small</string>
|
<string name="default_font_size">small</string>
|
||||||
<bool name="use_share_location_plugin">false</bool>
|
<bool name="use_share_location_plugin">false</bool>
|
||||||
<bool name="start_searching">false</bool>
|
<bool name="start_searching">false</bool>
|
||||||
|
<string name="video_compression">360</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -740,4 +740,9 @@
|
||||||
<string name="media_browser">Media browser</string>
|
<string name="media_browser">Media browser</string>
|
||||||
<string name="export_channel_name">History export</string>
|
<string name="export_channel_name">History export</string>
|
||||||
<string name="security_violation_not_attaching_file">File omitted due to security violation.</string>
|
<string name="security_violation_not_attaching_file">File omitted due to security violation.</string>
|
||||||
|
<string name="pref_video_compression">Compress Videos</string>
|
||||||
|
<string name="pref_video_compression_summary">Resize and compress videos</string>
|
||||||
|
<string name="video_360p">SD (360p)</string>
|
||||||
|
<string name="video_720p">HD (720p)</string>
|
||||||
|
<string name="video_1080p">Full HD (1080p)</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -137,6 +137,13 @@
|
||||||
android:key="picture_compression"
|
android:key="picture_compression"
|
||||||
android:summary="@string/pref_picture_compression_summary"
|
android:summary="@string/pref_picture_compression_summary"
|
||||||
android:title="@string/pref_picture_compression" />
|
android:title="@string/pref_picture_compression" />
|
||||||
|
<ListPreference
|
||||||
|
android:defaultValue="@string/video_compression"
|
||||||
|
android:entries="@array/video_compression_entries"
|
||||||
|
android:entryValues="@array/video_compression_values"
|
||||||
|
android:key="video_compression"
|
||||||
|
android:summary="@string/pref_video_compression_summary"
|
||||||
|
android:title="@string/pref_video_compression" />
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="@bool/use_share_location_plugin"
|
android:defaultValue="@bool/use_share_location_plugin"
|
||||||
android:key="use_share_location_plugin"
|
android:key="use_share_location_plugin"
|
||||||
|
|
Loading…
Reference in New Issue