m3u playlist support
This commit is contained in:
parent
674a453ab5
commit
197a85621c
3 changed files with 98 additions and 17 deletions
|
@ -19,7 +19,8 @@
|
||||||
android:roundIcon="@mipmap/ic_launcher_round"
|
android:roundIcon="@mipmap/ic_launcher_round"
|
||||||
android:supportsRtl="true"
|
android:supportsRtl="true"
|
||||||
android:theme="@style/Theme.AsgardiusS3Manager"
|
android:theme="@style/Theme.AsgardiusS3Manager"
|
||||||
tools:targetApi="31" >
|
tools:targetApi="31"
|
||||||
|
android:usesCleartextTraffic="true" >
|
||||||
<activity
|
<activity
|
||||||
android:name=".Settings"
|
android:name=".Settings"
|
||||||
android:configChanges="orientation|keyboardHidden|screenSize|smallestScreenSize|screenLayout|uiMode|keyboardHidden"
|
android:configChanges="orientation|keyboardHidden|screenSize|smallestScreenSize|screenLayout|uiMode|keyboardHidden"
|
||||||
|
|
|
@ -16,10 +16,15 @@ import com.amazonaws.regions.Region;
|
||||||
import com.amazonaws.services.s3.AmazonS3;
|
import com.amazonaws.services.s3.AmazonS3;
|
||||||
import com.amazonaws.services.s3.AmazonS3Client;
|
import com.amazonaws.services.s3.AmazonS3Client;
|
||||||
import com.amazonaws.services.s3.S3ClientOptions;
|
import com.amazonaws.services.s3.S3ClientOptions;
|
||||||
|
import com.amazonaws.services.s3.model.GeneratePresignedUrlRequest;
|
||||||
import com.amazonaws.services.s3.model.ListObjectsRequest;
|
import com.amazonaws.services.s3.model.ListObjectsRequest;
|
||||||
import com.amazonaws.services.s3.model.ObjectListing;
|
import com.amazonaws.services.s3.model.ObjectListing;
|
||||||
import com.amazonaws.services.s3.model.S3ObjectSummary;
|
import com.amazonaws.services.s3.model.S3ObjectSummary;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
@ -179,7 +184,7 @@ public class ObjectSelect extends AppCompatActivity {
|
||||||
else if (Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".opus") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".ogg")
|
else if (Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".opus") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".ogg")
|
||||||
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".oga") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mp3")
|
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".oga") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mp3")
|
||||||
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".m4a") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".flac")
|
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".m4a") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".flac")
|
||||||
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mka")) {
|
|| Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mka") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".m3u")) {
|
||||||
Img.add(R.drawable.audiofile);
|
Img.add(R.drawable.audiofile);
|
||||||
}
|
}
|
||||||
else if(Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mp4") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mkv")
|
else if(Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mp4") || Name.get(i).toString().toLowerCase(Locale.ROOT).endsWith(".mkv")
|
||||||
|
@ -235,7 +240,7 @@ public class ObjectSelect extends AppCompatActivity {
|
||||||
explorer(Name.get(position).toString());
|
explorer(Name.get(position).toString());
|
||||||
} else if (Img.get(position).equals(R.drawable.audiofile) || Img.get(position).equals(R.drawable.videofile)) {
|
} else if (Img.get(position).equals(R.drawable.audiofile) || Img.get(position).equals(R.drawable.videofile)) {
|
||||||
simpleProgressBar.setVisibility(View.VISIBLE);
|
simpleProgressBar.setVisibility(View.VISIBLE);
|
||||||
if (isplaylist) {
|
if (isplaylist && !Name.get(position).toString().toLowerCase(Locale.ROOT).endsWith(".m3u")) {
|
||||||
videoPlayer(null, Name.get(position).toString());
|
videoPlayer(null, Name.get(position).toString());
|
||||||
} else {
|
} else {
|
||||||
Thread mediaread = new Thread(new Runnable() {
|
Thread mediaread = new Thread(new Runnable() {
|
||||||
|
@ -300,7 +305,55 @@ public class ObjectSelect extends AppCompatActivity {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void videoPlayer(String url, String title) {
|
private void videoPlayer(String url, String title) {
|
||||||
if (isplaylist) {
|
if (title.toLowerCase(Locale.ROOT).endsWith(".m3u")) {
|
||||||
|
Thread mediaread = new Thread(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
//load media file
|
||||||
|
ArrayList<String> links = getPlaylist(url);
|
||||||
|
ArrayList<String> medialist = new ArrayList<String>();
|
||||||
|
for (int i = 0; i < links.size(); i++) {
|
||||||
|
medialist.add(links.get(i).toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
// Sending reference and data to Adapter
|
||||||
|
//videoPlayer(objectURL.toString(), Name.get(position).toString());
|
||||||
|
Intent intent = new Intent(getApplicationContext(), VideoPlayer.class);
|
||||||
|
intent.putExtra("video_url", url);
|
||||||
|
intent.putExtra("title", title);
|
||||||
|
intent.putExtra("videocache", videocache);
|
||||||
|
intent.putExtra("buffersize", buffersize);
|
||||||
|
intent.putExtra("isplaylist", true);
|
||||||
|
intent.putExtra("queue", links);
|
||||||
|
intent.putExtra("names", medialist);
|
||||||
|
simpleProgressBar.setVisibility(View.INVISIBLE);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
//System.out.println("tree "+treelevel);
|
||||||
|
//System.out.println("prefix "+prefix);
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
mediaread.start();
|
||||||
|
}
|
||||||
|
else if (isplaylist) {
|
||||||
Thread mediaread = new Thread(new Runnable() {
|
Thread mediaread = new Thread(new Runnable() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -319,18 +372,20 @@ public class ObjectSelect extends AppCompatActivity {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
// Sending reference and data to Adapter
|
if(links != null) {
|
||||||
//videoPlayer(objectURL.toString(), Name.get(position).toString());
|
// Sending reference and data to Adapter
|
||||||
Intent intent = new Intent(getApplicationContext(), VideoPlayer.class);
|
//videoPlayer(objectURL.toString(), Name.get(position).toString());
|
||||||
intent.putExtra("video_url", url);
|
Intent intent = new Intent(getApplicationContext(), VideoPlayer.class);
|
||||||
intent.putExtra("title", title);
|
intent.putExtra("video_url", url);
|
||||||
intent.putExtra("videocache", videocache);
|
intent.putExtra("title", title);
|
||||||
intent.putExtra("buffersize", buffersize);
|
intent.putExtra("videocache", videocache);
|
||||||
intent.putExtra("isplaylist", isplaylist);
|
intent.putExtra("buffersize", buffersize);
|
||||||
intent.putExtra("queue", links);
|
intent.putExtra("isplaylist", isplaylist);
|
||||||
intent.putExtra("names", medialist);
|
intent.putExtra("queue", links);
|
||||||
simpleProgressBar.setVisibility(View.INVISIBLE);
|
intent.putExtra("names", medialist);
|
||||||
startActivity(intent);
|
simpleProgressBar.setVisibility(View.INVISIBLE);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
//System.out.println("tree "+treelevel);
|
//System.out.println("tree "+treelevel);
|
||||||
|
@ -398,4 +453,25 @@ public class ObjectSelect extends AppCompatActivity {
|
||||||
}
|
}
|
||||||
return links;
|
return links;
|
||||||
}
|
}
|
||||||
|
public ArrayList<String> getPlaylist(String playlist) {
|
||||||
|
ArrayList<String> links = new ArrayList<String>();
|
||||||
|
try {
|
||||||
|
BufferedReader br = new BufferedReader(new InputStreamReader((new URL(playlist).openStream())));
|
||||||
|
String strLine;
|
||||||
|
|
||||||
|
//Read File Line By Line
|
||||||
|
while ((strLine = br.readLine()) != null) {
|
||||||
|
// Print the content on the console - do what you want to do
|
||||||
|
if(!strLine.startsWith("#")) {
|
||||||
|
links.add(strLine);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Close the input stream
|
||||||
|
return links;
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -219,7 +219,11 @@ public class VideoPlayer extends AppCompatActivity {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
player.prepare();
|
player.prepare();
|
||||||
player.seekTo(names.indexOf(title), 0);
|
try {
|
||||||
|
player.seekTo(names.indexOf(title), 0);
|
||||||
|
}catch (Exception e) {
|
||||||
|
System.out.println("Playing m3u file");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (title.endsWith(".m3u8")) {
|
if (title.endsWith(".m3u8")) {
|
||||||
MediaItem mediaItem = MediaItem.fromUri(URLify(videoURL));
|
MediaItem mediaItem = MediaItem.fromUri(URLify(videoURL));
|
||||||
|
|
Loading…
Reference in a new issue