add separate drawables for youtube and video links, better cover drawable
@ -74,6 +74,8 @@ import java.util.ArrayList;
|
|||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class HeadlinesFragment extends Fragment implements OnItemClickListener, OnScrollListener {
|
public class HeadlinesFragment extends Fragment implements OnItemClickListener, OnScrollListener {
|
||||||
public static enum ArticlesSelection { ALL, NONE, UNREAD }
|
public static enum ArticlesSelection { ALL, NONE, UNREAD }
|
||||||
@ -1032,6 +1034,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener,
|
|||||||
|
|
||||||
if (article.articleDoc != null && holder.flavorVideoPlayView != null) {
|
if (article.articleDoc != null && holder.flavorVideoPlayView != null) {
|
||||||
Element video = article.articleDoc.select("video").first();
|
Element video = article.articleDoc.select("video").first();
|
||||||
|
Element ytframe = article.articleDoc.select("iframe[src*=youtube.com/embed/]").first();
|
||||||
|
|
||||||
if (video != null) {
|
if (video != null) {
|
||||||
try {
|
try {
|
||||||
@ -1040,7 +1043,9 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener,
|
|||||||
final String streamUri = source.attr("src");
|
final String streamUri = source.attr("src");
|
||||||
String posterUri = video.attr("poster");
|
String posterUri = video.attr("poster");
|
||||||
|
|
||||||
if (streamUri != null && posterUri != null) {
|
Log.d(TAG, posterUri);
|
||||||
|
|
||||||
|
if (streamUri.length() > 0 && posterUri.length() > 0) {
|
||||||
|
|
||||||
if (!posterUri.equals(holder.flavorImageView.getTag())) {
|
if (!posterUri.equals(holder.flavorImageView.getTag())) {
|
||||||
holder.flavorImageView.setTag(posterUri);
|
holder.flavorImageView.setTag(posterUri);
|
||||||
@ -1055,6 +1060,7 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener,
|
|||||||
holder.flavorImageLoadingBar.setVisibility(View.GONE);
|
holder.flavorImageLoadingBar.setVisibility(View.GONE);
|
||||||
holder.flavorImageView.setVisibility(View.VISIBLE);
|
holder.flavorImageView.setVisibility(View.VISIBLE);
|
||||||
holder.flavorVideoPlayView.setVisibility(View.VISIBLE);
|
holder.flavorVideoPlayView.setVisibility(View.VISIBLE);
|
||||||
|
holder.flavorVideoPlayView.setImageResource(R.drawable.flavor_video_play);
|
||||||
|
|
||||||
ViewCompat.setTransitionName(holder.flavorImageView, "TRANSITION:ARTICLE_VIDEO_PLAYER");
|
ViewCompat.setTransitionName(holder.flavorImageView, "TRANSITION:ARTICLE_VIDEO_PLAYER");
|
||||||
|
|
||||||
@ -1082,6 +1088,39 @@ public class HeadlinesFragment extends Fragment implements OnItemClickListener,
|
|||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
videoFound = false;
|
videoFound = false;
|
||||||
}
|
}
|
||||||
|
} else if (ytframe != null) {
|
||||||
|
// thumb: http://img.youtube.com/vi/{VID}/mqdefault.jpg
|
||||||
|
String srcEmbed = ytframe.attr("src");
|
||||||
|
|
||||||
|
if (srcEmbed.length() > 0) {
|
||||||
|
Pattern pattern = Pattern.compile("/embed/([\\w-]+)");
|
||||||
|
Matcher matcher = pattern.matcher(srcEmbed);
|
||||||
|
|
||||||
|
if (matcher.find()) {
|
||||||
|
String vid = matcher.group(1);
|
||||||
|
String thumbUri = "http://img.youtube.com/vi/"+vid+"/mqdefault.jpg";
|
||||||
|
final String videoUri = "https://youtu.be/" + vid;
|
||||||
|
|
||||||
|
videoFound = true;
|
||||||
|
|
||||||
|
holder.flavorImageLoadingBar.setVisibility(View.GONE);
|
||||||
|
holder.flavorImageView.setVisibility(View.VISIBLE);
|
||||||
|
holder.flavorVideoPlayView.setVisibility(View.VISIBLE);
|
||||||
|
holder.flavorVideoPlayView.setImageResource(R.drawable.flavor_video_play_youtube);
|
||||||
|
|
||||||
|
ImageAware imageAware = new ImageViewAware(holder.flavorImageView, false);
|
||||||
|
m_imageLoader.displayImage(thumbUri, imageAware, displayImageOptions);
|
||||||
|
|
||||||
|
holder.flavorImageView.setOnClickListener(new OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
Intent intent = new Intent(Intent.ACTION_VIEW,
|
||||||
|
Uri.parse(videoUri));
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
BIN
org.fox.ttrss/src/main/res/drawable-hdpi/ic_play_circle.png
Normal file
After Width: | Height: | Size: 889 B |
Before Width: | Height: | Size: 807 B After Width: | Height: | Size: 686 B |
BIN
org.fox.ttrss/src/main/res/drawable-xhdpi/ic_play_circle.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 883 B |
BIN
org.fox.ttrss/src/main/res/drawable-xxhdpi/ic_play_circle.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.2 KiB |
BIN
org.fox.ttrss/src/main/res/drawable-xxxhdpi/ic_play_circle.png
Normal file
After Width: | Height: | Size: 2.3 KiB |
Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 1.6 KiB |
15
org.fox.ttrss/src/main/res/drawable/flavor_video_play.xml
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<layer-list
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android" >
|
||||||
|
|
||||||
|
<item>
|
||||||
|
<shape android:shape="rectangle">
|
||||||
|
<solid android:color="#90000000" />
|
||||||
|
</shape>
|
||||||
|
</item>
|
||||||
|
|
||||||
|
<item>
|
||||||
|
<bitmap android:src="@drawable/ic_play_circle"
|
||||||
|
android:gravity="center" />
|
||||||
|
</item>
|
||||||
|
</layer-list>
|
@ -0,0 +1,15 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<layer-list
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android" >
|
||||||
|
|
||||||
|
<item>
|
||||||
|
<shape android:shape="rectangle">
|
||||||
|
<solid android:color="#90000000" />
|
||||||
|
</shape>
|
||||||
|
</item>
|
||||||
|
|
||||||
|
<item>
|
||||||
|
<bitmap android:src="@drawable/ic_youtube_play"
|
||||||
|
android:gravity="center" />
|
||||||
|
</item>
|
||||||
|
</layer-list>
|
@ -93,10 +93,11 @@
|
|||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/flavor_video_play"
|
android:id="@+id/flavor_video_play"
|
||||||
android:layout_width="64dp"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="64dp"
|
android:layout_height="match_parent"
|
||||||
android:layout_gravity="center"
|
android:layout_gravity="center"
|
||||||
android:src="@drawable/ic_youtube_play"
|
android:scaleType="fitXY"
|
||||||
|
android:src="@drawable/flavor_video_play"
|
||||||
android:visibility="gone" />
|
android:visibility="gone" />
|
||||||
|
|
||||||
<org.fox.ttrss.util.ArrowRight
|
<org.fox.ttrss.util.ArrowRight
|
||||||
|
@ -98,7 +98,8 @@
|
|||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_gravity="center"
|
android:layout_gravity="center"
|
||||||
android:src="@drawable/ic_youtube_play"
|
android:scaleType="fitXY"
|
||||||
|
android:src="@drawable/flavor_video_play"
|
||||||
android:visibility="gone" />
|
android:visibility="gone" />
|
||||||
|
|
||||||
<org.fox.ttrss.util.ArrowRight
|
<org.fox.ttrss.util.ArrowRight
|
||||||
|