preferences
This commit is contained in:
parent
48fa899a97
commit
cd0b72a887
7 changed files with 171 additions and 17 deletions
|
@ -33,8 +33,6 @@ public class MainActivity extends AppCompatActivity {
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
isplaylist = true;
|
|
||||||
playlisttime = 1;
|
|
||||||
|
|
||||||
recyclerView = findViewById(R.id.alist);
|
recyclerView = findViewById(R.id.alist);
|
||||||
|
|
||||||
|
@ -70,6 +68,8 @@ public class MainActivity extends AppCompatActivity {
|
||||||
db.execSQL("INSERT INTO preferences VALUES ('videocache', '300')");
|
db.execSQL("INSERT INTO preferences VALUES ('videocache', '300')");
|
||||||
db.execSQL("INSERT INTO preferences VALUES ('videotime', '3')");
|
db.execSQL("INSERT INTO preferences VALUES ('videotime', '3')");
|
||||||
db.execSQL("INSERT INTO preferences VALUES ('buffersize', '12000')");
|
db.execSQL("INSERT INTO preferences VALUES ('buffersize', '12000')");
|
||||||
|
db.execSQL("INSERT INTO preferences VALUES ('playlisttime', '5')");
|
||||||
|
db.execSQL("INSERT INTO preferences VALUES ('isplaylist', '0')");
|
||||||
videocache = 300;
|
videocache = 300;
|
||||||
//videotime = 3;
|
//videotime = 3;
|
||||||
db.close();
|
db.close();
|
||||||
|
@ -119,6 +119,74 @@ public class MainActivity extends AppCompatActivity {
|
||||||
//Toast.makeText(getApplicationContext(),getResources().getString(R.string.media_list_fail), Toast.LENGTH_SHORT).show();
|
//Toast.makeText(getApplicationContext(),getResources().getString(R.string.media_list_fail), Toast.LENGTH_SHORT).show();
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
|
try {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
String query = "SELECT value FROM preferences where setting='playlisttime'";
|
||||||
|
Cursor cursor = db.rawQuery(query,null);
|
||||||
|
while (cursor.moveToNext()){
|
||||||
|
playlisttime = (Integer.parseInt(cursor.getString(0)));
|
||||||
|
}
|
||||||
|
db.close();
|
||||||
|
if (playlisttime == 0) {
|
||||||
|
try {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
db.execSQL("INSERT INTO preferences VALUES ('playlisttime', '5')");
|
||||||
|
playlisttime = 5;
|
||||||
|
db.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
db.execSQL("CREATE TABLE IF NOT EXISTS preferences(setting text UNIQUE, value text)");
|
||||||
|
db.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
Toast.makeText(getApplicationContext(),getResources().getString(R.string.broken_database), Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
//Toast.makeText(getApplicationContext(),getResources().getString(R.string.media_list_fail), Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
String query = "SELECT value FROM preferences where setting='isplaylist'";
|
||||||
|
Cursor cursor = db.rawQuery(query,null);
|
||||||
|
String update = null;
|
||||||
|
while (cursor.moveToNext()){
|
||||||
|
isplaylist = cursor.getString(0).equals("1");
|
||||||
|
if(!isplaylist) {
|
||||||
|
update = cursor.getString(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
db.close();
|
||||||
|
if (!isplaylist && update == null) {
|
||||||
|
try {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
db.execSQL("INSERT INTO preferences VALUES ('isplaylist', '0')");
|
||||||
|
isplaylist = false;
|
||||||
|
db.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
db = dbHelper.getWritableDatabase();
|
||||||
|
db.execSQL("CREATE TABLE IF NOT EXISTS preferences(setting text UNIQUE, value text)");
|
||||||
|
db.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
Toast.makeText(getApplicationContext(),getResources().getString(R.string.broken_database), Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
//Toast.makeText(getApplicationContext(),getResources().getString(R.string.media_list_fail), Toast.LENGTH_SHORT).show();
|
||||||
|
finish();
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
db = dbHelper.getWritableDatabase();
|
db = dbHelper.getWritableDatabase();
|
||||||
String query = "SELECT value FROM preferences where setting='buffersize'";
|
String query = "SELECT value FROM preferences where setting='buffersize'";
|
||||||
|
|
|
@ -10,6 +10,8 @@ public class MyDbHelper extends SQLiteOpenHelper {
|
||||||
private static final String setvideocache = "INSERT INTO preferences VALUES ('videocache', '300')";
|
private static final String setvideocache = "INSERT INTO preferences VALUES ('videocache', '300')";
|
||||||
private static final String setvideotime = "INSERT INTO preferences VALUES ('videotime', '3')";
|
private static final String setvideotime = "INSERT INTO preferences VALUES ('videotime', '3')";
|
||||||
private static final String setbuffersize = "INSERT INTO preferences VALUES ('buffersize', '12000')";
|
private static final String setbuffersize = "INSERT INTO preferences VALUES ('buffersize', '12000')";
|
||||||
|
private static final String setplaylisttime = "INSERT INTO preferences VALUES ('playlisttime', '5')";
|
||||||
|
private static final String setisplaylist = "INSERT INTO preferences VALUES ('isplaylist', '0')";
|
||||||
//private static final String upgrade = "ALTER TABLE account add column pdfendpoint text";
|
//private static final String upgrade = "ALTER TABLE account add column pdfendpoint text";
|
||||||
private static final int DATABASE_VERSION = 1;
|
private static final int DATABASE_VERSION = 1;
|
||||||
private static final String dbname = "accounts.sqlite3";
|
private static final String dbname = "accounts.sqlite3";
|
||||||
|
@ -24,6 +26,8 @@ public class MyDbHelper extends SQLiteOpenHelper {
|
||||||
db.execSQL(setvideocache);
|
db.execSQL(setvideocache);
|
||||||
db.execSQL(setvideotime);
|
db.execSQL(setvideotime);
|
||||||
db.execSQL(setbuffersize);
|
db.execSQL(setbuffersize);
|
||||||
|
db.execSQL(setplaylisttime);
|
||||||
|
db.execSQL(setisplaylist);
|
||||||
}
|
}
|
||||||
@Override
|
@Override
|
||||||
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
||||||
|
|
|
@ -13,6 +13,8 @@ import android.widget.Button;
|
||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.google.android.material.switchmaterial.SwitchMaterial;
|
||||||
|
|
||||||
import asgardius.page.s3manager.databinding.ActivitySettingsBinding;
|
import asgardius.page.s3manager.databinding.ActivitySettingsBinding;
|
||||||
|
|
||||||
public class Settings extends AppCompatActivity {
|
public class Settings extends AppCompatActivity {
|
||||||
|
@ -20,9 +22,10 @@ public class Settings extends AppCompatActivity {
|
||||||
private ActivitySettingsBinding binding;
|
private ActivitySettingsBinding binding;
|
||||||
MyDbHelper dbHelper;
|
MyDbHelper dbHelper;
|
||||||
SQLiteDatabase db;
|
SQLiteDatabase db;
|
||||||
String videocache, videotime, buffersize;
|
String videocache, videotime, buffersize, playlisttime;
|
||||||
EditText vcachepick, vtimepick, bsizepick;
|
EditText vcachepick, vtimepick, bsizepick, ptimepick;
|
||||||
Button saveprefs, about;
|
Button saveprefs, about;
|
||||||
|
SwitchMaterial isplaylist;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
@ -33,7 +36,9 @@ public class Settings extends AppCompatActivity {
|
||||||
vcachepick = (EditText)findViewById(R.id.videocache);
|
vcachepick = (EditText)findViewById(R.id.videocache);
|
||||||
vtimepick = (EditText)findViewById(R.id.videotime);
|
vtimepick = (EditText)findViewById(R.id.videotime);
|
||||||
bsizepick = (EditText)findViewById(R.id.buffersize);
|
bsizepick = (EditText)findViewById(R.id.buffersize);
|
||||||
|
ptimepick = (EditText)findViewById(R.id.playlisttime);
|
||||||
dbHelper = new MyDbHelper(this);
|
dbHelper = new MyDbHelper(this);
|
||||||
|
isplaylist = (SwitchMaterial) findViewById(R.id.isplaylist);
|
||||||
Thread getprefs = new Thread(new Runnable() {
|
Thread getprefs = new Thread(new Runnable() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -57,6 +62,16 @@ public class Settings extends AppCompatActivity {
|
||||||
while (cursor.moveToNext()){
|
while (cursor.moveToNext()){
|
||||||
buffersize = (cursor.getString(0));
|
buffersize = (cursor.getString(0));
|
||||||
}
|
}
|
||||||
|
query = "SELECT value FROM preferences where setting='isplaylist'";
|
||||||
|
cursor = db.rawQuery(query,null);
|
||||||
|
while (cursor.moveToNext()){
|
||||||
|
isplaylist.setChecked(cursor.getString(0).equals("1"));
|
||||||
|
}
|
||||||
|
query = "SELECT value FROM preferences where setting='playlisttime'";
|
||||||
|
cursor = db.rawQuery(query,null);
|
||||||
|
while (cursor.moveToNext()){
|
||||||
|
playlisttime = (cursor.getString(0));
|
||||||
|
}
|
||||||
db.close();
|
db.close();
|
||||||
runOnUiThread(new Runnable() {
|
runOnUiThread(new Runnable() {
|
||||||
|
|
||||||
|
@ -66,6 +81,7 @@ public class Settings extends AppCompatActivity {
|
||||||
vcachepick.setText(videocache);
|
vcachepick.setText(videocache);
|
||||||
vtimepick.setText(videotime);
|
vtimepick.setText(videotime);
|
||||||
bsizepick.setText(buffersize);
|
bsizepick.setText(buffersize);
|
||||||
|
ptimepick.setText(playlisttime);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -94,9 +110,10 @@ public class Settings extends AppCompatActivity {
|
||||||
videocache = vcachepick.getText().toString();
|
videocache = vcachepick.getText().toString();
|
||||||
videotime = vtimepick.getText().toString();
|
videotime = vtimepick.getText().toString();
|
||||||
buffersize = bsizepick.getText().toString();
|
buffersize = bsizepick.getText().toString();
|
||||||
|
playlisttime = ptimepick.getText().toString();
|
||||||
if (videocache.equals("") || videotime.equals("") || buffersize.equals("")) {
|
if (videocache.equals("") || videotime.equals("") || buffersize.equals("")) {
|
||||||
Toast.makeText(getApplicationContext(),getResources().getString(R.string.accountadd_null), Toast.LENGTH_SHORT).show();
|
Toast.makeText(getApplicationContext(),getResources().getString(R.string.accountadd_null), Toast.LENGTH_SHORT).show();
|
||||||
} else if (videocache.equals("0") || videotime.equals("0")) {
|
} else if (videocache.equals("0") || videotime.equals("0") || playlisttime.equals("0")) {
|
||||||
Toast.makeText(getApplicationContext(),getResources().getString(R.string.not_zero), Toast.LENGTH_SHORT).show();
|
Toast.makeText(getApplicationContext(),getResources().getString(R.string.not_zero), Toast.LENGTH_SHORT).show();
|
||||||
} else if (Integer.parseInt(buffersize) <= 2000) {
|
} else if (Integer.parseInt(buffersize) <= 2000) {
|
||||||
Toast.makeText(getApplicationContext(),getResources().getString(R.string.buffersize_error), Toast.LENGTH_SHORT).show();
|
Toast.makeText(getApplicationContext(),getResources().getString(R.string.buffersize_error), Toast.LENGTH_SHORT).show();
|
||||||
|
@ -107,6 +124,12 @@ public class Settings extends AppCompatActivity {
|
||||||
db.execSQL("UPDATE preferences SET value='" + videocache + "' where setting='videocache'");
|
db.execSQL("UPDATE preferences SET value='" + videocache + "' where setting='videocache'");
|
||||||
db.execSQL("UPDATE preferences SET value='" + videotime + "' where setting='videotime'");
|
db.execSQL("UPDATE preferences SET value='" + videotime + "' where setting='videotime'");
|
||||||
db.execSQL("UPDATE preferences SET value='" + buffersize + "' where setting='buffersize'");
|
db.execSQL("UPDATE preferences SET value='" + buffersize + "' where setting='buffersize'");
|
||||||
|
db.execSQL("UPDATE preferences SET value='" + playlisttime + "' where setting='playlisttime'");
|
||||||
|
if(isplaylist.isChecked()) {
|
||||||
|
db.execSQL("UPDATE preferences SET value='1' where setting='isplaylist'");
|
||||||
|
} else {
|
||||||
|
db.execSQL("UPDATE preferences SET value='0' where setting='isplaylist'");
|
||||||
|
}
|
||||||
db.close();
|
db.close();
|
||||||
mainmenu();
|
mainmenu();
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,6 +146,8 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
// Prepare the player.
|
// Prepare the player.
|
||||||
player.setPlayWhenReady(true);
|
player.setPlayWhenReady(true);
|
||||||
playerNotificationManager = new PlayerNotificationManager.Builder(this, notificationId, "playback").build();
|
playerNotificationManager = new PlayerNotificationManager.Builder(this, notificationId, "playback").build();
|
||||||
|
playerNotificationManager.setUseNextActionInCompactView(true);
|
||||||
|
playerNotificationManager.setUsePreviousActionInCompactView(true);
|
||||||
playerNotificationManager.setMediaSessionToken(mediaSession.getSessionToken());
|
playerNotificationManager.setMediaSessionToken(mediaSession.getSessionToken());
|
||||||
playerNotificationManager.setPlayer(player);
|
playerNotificationManager.setPlayer(player);
|
||||||
if (isplaylist) {
|
if (isplaylist) {
|
||||||
|
@ -225,6 +227,9 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
mWakeLock.acquire();
|
mWakeLock.acquire();
|
||||||
//System.out.println("WakeLock acquired");
|
//System.out.println("WakeLock acquired");
|
||||||
}
|
}
|
||||||
|
if(isplaylist) {
|
||||||
|
getSupportActionBar().setTitle(names.get(player.getCurrentMediaItemIndex()));
|
||||||
|
}
|
||||||
} else if (state == 2) {
|
} else if (state == 2) {
|
||||||
// Buffering.
|
// Buffering.
|
||||||
//Acquiring WakeLock and WifiLock if not held
|
//Acquiring WakeLock and WifiLock if not held
|
||||||
|
@ -236,6 +241,9 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
mWakeLock.acquire();
|
mWakeLock.acquire();
|
||||||
//System.out.println("WakeLock acquired");
|
//System.out.println("WakeLock acquired");
|
||||||
}
|
}
|
||||||
|
if(isplaylist) {
|
||||||
|
getSupportActionBar().setTitle(names.get(player.getCurrentMediaItemIndex()));
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
//Player inactive
|
//Player inactive
|
||||||
//Releasing WifiLock and WakeLock if held
|
//Releasing WifiLock and WakeLock if held
|
||||||
|
@ -323,6 +331,7 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
|
|
||||||
public void onDestroy() {
|
public void onDestroy() {
|
||||||
mediaSessionConnector.setPlayer(null);
|
mediaSessionConnector.setPlayer(null);
|
||||||
|
standaloneDatabaseProvider.close();
|
||||||
mediaSession.setActive(false);
|
mediaSession.setActive(false);
|
||||||
playerNotificationManager.setPlayer(null);
|
playerNotificationManager.setPlayer(null);
|
||||||
player.release();
|
player.release();
|
||||||
|
@ -350,21 +359,43 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
videocache = intent.getIntExtra("videocache", 40);
|
videocache = intent.getIntExtra("videocache", 40);
|
||||||
buffersize = intent.getIntExtra("buffersize", 2000);
|
buffersize = intent.getIntExtra("buffersize", 2000);
|
||||||
isplaylist = intent.getBooleanExtra("isplaylist", false);
|
isplaylist = intent.getBooleanExtra("isplaylist", false);
|
||||||
|
queue = intent.getStringArrayListExtra("queue");
|
||||||
|
names = intent.getStringArrayListExtra("names");
|
||||||
getSupportActionBar().setTitle(title);
|
getSupportActionBar().setTitle(title);
|
||||||
|
if (isplaylist) {
|
||||||
|
for (int i = 0; i < queue.size(); i++) {
|
||||||
|
if (names.get(i).endsWith(".m3u8")) {
|
||||||
|
MediaItem mediaItem = MediaItem.fromUri(queue.get(i));
|
||||||
|
player.addMediaItem(mediaItem);
|
||||||
|
} else {
|
||||||
mediaSource = new ProgressiveMediaSource.Factory(
|
mediaSource = new ProgressiveMediaSource.Factory(
|
||||||
new CacheDataSource.Factory()
|
new CacheDataSource.Factory()
|
||||||
.setCache(simpleCache)
|
.setCache(simpleCache)
|
||||||
.setUpstreamDataSourceFactory(new DefaultHttpDataSource.Factory()
|
.setUpstreamDataSourceFactory(new DefaultHttpDataSource.Factory()
|
||||||
.setUserAgent("ExoplayerDemo"))
|
.setUserAgent("S3 Manager"))
|
||||||
.setFlags(CacheDataSource.FLAG_IGNORE_CACHE_ON_ERROR)
|
.setFlags(CacheDataSource.FLAG_IGNORE_CACHE_ON_ERROR)
|
||||||
).createMediaSource(MediaItem.fromUri(Uri.parse(videoURL)));
|
).createMediaSource(MediaItem.fromUri(Uri.parse(queue.get(i))));
|
||||||
|
player.addMediaSource(mediaSource);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
player.prepare();
|
||||||
|
player.seekTo(names.indexOf(title), 0);
|
||||||
|
} else {
|
||||||
if (title.endsWith(".m3u8")) {
|
if (title.endsWith(".m3u8")) {
|
||||||
MediaItem mediaItem = MediaItem.fromUri(videoURL);
|
MediaItem mediaItem = MediaItem.fromUri(videoURL);
|
||||||
player.setMediaItem(mediaItem);
|
player.setMediaItem(mediaItem);
|
||||||
} else {
|
} else {
|
||||||
|
mediaSource = new ProgressiveMediaSource.Factory(
|
||||||
|
new CacheDataSource.Factory()
|
||||||
|
.setCache(simpleCache)
|
||||||
|
.setUpstreamDataSourceFactory(new DefaultHttpDataSource.Factory()
|
||||||
|
.setUserAgent("S3 Manager"))
|
||||||
|
.setFlags(CacheDataSource.FLAG_IGNORE_CACHE_ON_ERROR)
|
||||||
|
).createMediaSource(MediaItem.fromUri(Uri.parse(videoURL)));
|
||||||
player.setMediaSource(mediaSource);
|
player.setMediaSource(mediaSource);
|
||||||
}
|
}
|
||||||
player.prepare();
|
player.prepare();
|
||||||
|
}
|
||||||
// Start the playback.
|
// Start the playback.
|
||||||
player.play();
|
player.play();
|
||||||
super.onNewIntent(intent);
|
super.onNewIntent(intent);
|
||||||
|
|
|
@ -65,6 +65,30 @@
|
||||||
android:inputType="number"
|
android:inputType="number"
|
||||||
android:textColorHint="?attr/colorOnSecondary"/>
|
android:textColorHint="?attr/colorOnSecondary"/>
|
||||||
|
|
||||||
|
<com.google.android.material.switchmaterial.SwitchMaterial
|
||||||
|
android:id="@+id/isplaylist"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="70dp"
|
||||||
|
android:text="@string/playlist_playback"
|
||||||
|
android:textSize="24sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/playlisttime"
|
||||||
|
android:textAlignment="center"
|
||||||
|
android:textSize="25sp"/>
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/playlisttime"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="48dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:focusable="true"
|
||||||
|
android:hint="@string/playlisttime"
|
||||||
|
android:inputType="number"
|
||||||
|
android:textColorHint="?attr/colorOnSecondary"/>
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/saveprefs"
|
android:id="@+id/saveprefs"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
|
|
@ -93,6 +93,8 @@
|
||||||
<string name="save_settings">Guardar ajustes</string>
|
<string name="save_settings">Guardar ajustes</string>
|
||||||
<string name="videocache">Tamaño máximo de cache multimedia (en MiB)</string>
|
<string name="videocache">Tamaño máximo de cache multimedia (en MiB)</string>
|
||||||
<string name="videotime">Tiempo de expiración para visor multimedia (en horas)</string>
|
<string name="videotime">Tiempo de expiración para visor multimedia (en horas)</string>
|
||||||
|
<string name="playlist_playback">Habilitar listas de reproducción</string>
|
||||||
|
<string name="playlisttime">Tiempo de expiración para listas de reproducción (en horas)</string>
|
||||||
<string name="buffersize">Tamaño del buffer del reproductor multimedia (en milisegundos)</string>
|
<string name="buffersize">Tamaño del buffer del reproductor multimedia (en milisegundos)</string>
|
||||||
<string name="buffersize_error">El tamaño del búfer debe ser de al menos 2001 milisegundos</string>
|
<string name="buffersize_error">El tamaño del búfer debe ser de al menos 2001 milisegundos</string>
|
||||||
<string name="mediaplayer_multierror">Solo se puede reproducir un archivo multimedia a la vez</string>
|
<string name="mediaplayer_multierror">Solo se puede reproducir un archivo multimedia a la vez</string>
|
||||||
|
|
|
@ -101,6 +101,8 @@
|
||||||
<string name="videotime">Expiration time for media viewer (in hours)</string>
|
<string name="videotime">Expiration time for media viewer (in hours)</string>
|
||||||
<string name="buffersize">Media player buffer size (in milliseconds)</string>
|
<string name="buffersize">Media player buffer size (in milliseconds)</string>
|
||||||
<string name="buffersize_error">Buffer size must be at least 2001 milliseconds</string>
|
<string name="buffersize_error">Buffer size must be at least 2001 milliseconds</string>
|
||||||
|
<string name="playlist_playback">Enable playlists</string>
|
||||||
|
<string name="playlisttime">Expiration time for media playlists (in hours)</string>
|
||||||
<string name="mediaplayer_multierror">Only one media file can be played at once</string>
|
<string name="mediaplayer_multierror">Only one media file can be played at once</string>
|
||||||
<string name="playback_channel_name">Video Playback</string>
|
<string name="playback_channel_name">Video Playback</string>
|
||||||
<string name="not_zero">This value cannot be zero</string>
|
<string name="not_zero">This value cannot be zero</string>
|
||||||
|
|
Loading…
Reference in a new issue