From 37d9be90958a9e37f51a6c304c2951d0cd8e3eba Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 8 Dec 2015 21:29:29 +0100 Subject: [PATCH] put fab button on top of video thumbnail --- app/src/main/AndroidManifest.xml | 3 +- .../newpipe/VideoItemDetailFragment.java | 56 ++- .../newpipe/views/DetailScrollView.java | 56 +++ .../drawable-nodpi/dummy_thumbnail_dark.png | Bin 0 -> 188 bytes .../layout-land/fragment_videoitem_detail.xml | 214 ----------- .../fragment_videoitem_detail.xml | 213 ----------- .../res/layout/fragment_videoitem_detail.xml | 335 +++++++++--------- app/src/main/res/values-v21/styles.xml | 5 + app/src/main/res/values/styles.xml | 4 + 9 files changed, 279 insertions(+), 607 deletions(-) create mode 100644 app/src/main/java/org/schabi/newpipe/views/DetailScrollView.java create mode 100644 app/src/main/res/drawable-nodpi/dummy_thumbnail_dark.png delete mode 100644 app/src/main/res/layout-land/fragment_videoitem_detail.xml delete mode 100644 app/src/main/res/layout-sw600dp/fragment_videoitem_detail.xml diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index ea64136cb..d3c17455e 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -24,7 +24,8 @@ + android:label="@string/title_videoitem_detail" + android:theme="@style/DetailViewTheme"> diff --git a/app/src/main/java/org/schabi/newpipe/VideoItemDetailFragment.java b/app/src/main/java/org/schabi/newpipe/VideoItemDetailFragment.java index 7a9dc5a05..e7e108c98 100644 --- a/app/src/main/java/org/schabi/newpipe/VideoItemDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/VideoItemDetailFragment.java @@ -7,6 +7,7 @@ import android.content.SharedPreferences; import android.content.res.Resources; import android.graphics.Bitmap; import android.graphics.BitmapFactory; +import android.graphics.Point; import android.os.Bundle; import android.os.Handler; import android.preference.PreferenceManager; @@ -27,7 +28,6 @@ import android.widget.FrameLayout; import android.widget.ImageView; import android.widget.ProgressBar; import android.widget.RelativeLayout; -import android.widget.ScrollView; import android.widget.TextView; import android.view.MenuItem; @@ -44,6 +44,7 @@ import java.util.Vector; import org.schabi.newpipe.services.VideoExtractor; import org.schabi.newpipe.services.ServiceList; import org.schabi.newpipe.services.StreamingService; +import org.schabi.newpipe.views.DetailScrollView; /** @@ -84,8 +85,10 @@ public class VideoItemDetailFragment extends Fragment { private VideoInfo currentVideoInfo = null; private boolean showNextVideoItem = false; - - private View thumbnailWindow; + private ImageView thumbnailView; + private View thumbnailWindowLayout; + private FloatingActionButton playVideoButton; + private Point initialThumbnailPos = new Point(0, 0); public interface OnInvokeCreateOptionsMenuListener { void createOptionsMenu(); @@ -225,6 +228,7 @@ public class VideoItemDetailFragment extends Fragment { Button similarVideosButton = (Button) activity.findViewById(R.id.detailShowSimilarButton); textContentLayout.setVisibility(View.VISIBLE); + playVideoButton.setVisibility(View.VISIBLE); progressBar.setVisibility(View.GONE); if(!showNextVideoItem) { nextVideoRootFrame.setVisibility(View.GONE); @@ -356,8 +360,12 @@ public class VideoItemDetailFragment extends Fragment { @Override public void onActivityCreated(Bundle savedInstanceBundle) { super.onActivityCreated(savedInstanceBundle); - FloatingActionButton playVideoButton = - (FloatingActionButton) getActivity().findViewById(R.id.playVideoButton); + Activity a = getActivity(); + playVideoButton = + (FloatingActionButton) a.findViewById(R.id.playVideoButton); + thumbnailWindowLayout = a.findViewById(R.id.detailVideoThumbnailWindowLayout); + Button backgroundButton = (Button) + a.findViewById(R.id.detailVideoThumbnailWindowBackgroundButton); // Sometimes when this fragment is not visible it still gets initiated // then we must not try to access objects of this fragment. @@ -396,6 +404,13 @@ public class VideoItemDetailFragment extends Fragment { } }); + backgroundButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + actionBarHandler.playVideo(); + } + }); + Button similarVideosButton = (Button) activity.findViewById(R.id.detailShowSimilarButton); similarVideosButton.setOnClickListener(new View.OnClickListener() { @Override @@ -411,16 +426,30 @@ public class VideoItemDetailFragment extends Fragment { } }); - ImageView thumbnailView = (ImageView) activity.findViewById(R.id.detailThumbnailView); - thumbnailWindow = activity.findViewById(R.id.detailVideoThumbnailWindow); + thumbnailView = (ImageView) activity.findViewById(R.id.detailThumbnailView); thumbnailView.addOnLayoutChangeListener(new View.OnLayoutChangeListener() { - // This is used to synchronize the thumbnailWindow inside the ScrollView with - // the actual size of the thumbnail. + // This is used to synchronize the thumbnailWindowButton and the playVideoButton + // inside the ScrollView with the actual size of the thumbnail. @Override public void onLayoutChange(View v, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) { - Log.d(TAG, Integer.toString(right - left) + " : " + Integer.toString(bottom - top)); - RelativeLayout.LayoutParams newLayoutParams = new RelativeLayout.LayoutParams(right - left, bottom - top); - thumbnailWindow.setLayoutParams(newLayoutParams); + RelativeLayout.LayoutParams newWindowLayoutParams = + (RelativeLayout.LayoutParams) thumbnailWindowLayout.getLayoutParams(); + newWindowLayoutParams.height = bottom - top; + thumbnailWindowLayout.setLayoutParams(newWindowLayoutParams); + + + initialThumbnailPos.set(top, left); + + } + }); + + DetailScrollView scrollView = (DetailScrollView) activity.findViewById(R.id.detailMainContent); + scrollView.setOnScrollViewListener(new DetailScrollView.OnScrollViewListener() { + // This is used to make the thumbnailView move half the speed than the content does + // while scrolling. + @Override + public void onScrollChanged(DetailScrollView v, int l, int t, int oldl, int oldt) { + //Log.d(TAG, Integer.toString(l) + " : " + Integer.toString(t)); } }); } @@ -433,7 +462,8 @@ public class VideoItemDetailFragment extends Fragment { String languageKey = getContext().getString(R.string.searchLanguage); //i know the following line defaults languageCode to "en", but java is picky about uninitialised values // Schabi: well lint tels me the value is redundant. I'll suppress it for now. - @SuppressWarnings("UnusedAssignment") String languageCode = "en"; + @SuppressWarnings("UnusedAssignment") + String languageCode = "en"; languageCode = sp.getString(languageKey, "en"); if(languageCode.length() == 2) { diff --git a/app/src/main/java/org/schabi/newpipe/views/DetailScrollView.java b/app/src/main/java/org/schabi/newpipe/views/DetailScrollView.java new file mode 100644 index 000000000..95fb42ad6 --- /dev/null +++ b/app/src/main/java/org/schabi/newpipe/views/DetailScrollView.java @@ -0,0 +1,56 @@ +package org.schabi.newpipe.views; + +import android.content.Context; +import android.util.AttributeSet; +import android.widget.ScrollView; + +/** + * Created by the-scrabi on 02.12.15. + * + * Copyright (C) Christian Schabesberger 2015 + * DetailScrollView.java is part of NewPipe. + * + * NewPipe is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * NewPipe is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with NewPipe. If not, see . + */ + +public class DetailScrollView extends ScrollView { + + OnScrollViewListener mOnScrollViewListener = null; + + public DetailScrollView(Context context) { + super(context); + } + + public DetailScrollView(Context context, AttributeSet attrs) { + super(context, attrs); + } + + public DetailScrollView(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + } + + public interface OnScrollViewListener { + void onScrollChanged( DetailScrollView v, int l, int t, int oldl, int oldt ); + } + + @Override + protected void onScrollChanged(int l, int t, int oldl, int oldt) { + mOnScrollViewListener.onScrollChanged(this, l, t, oldl, oldt); + super.onScrollChanged(l, t, oldl, oldt); + } + + public void setOnScrollViewListener(OnScrollViewListener listener) { + mOnScrollViewListener = listener; + } +} diff --git a/app/src/main/res/drawable-nodpi/dummy_thumbnail_dark.png b/app/src/main/res/drawable-nodpi/dummy_thumbnail_dark.png new file mode 100644 index 0000000000000000000000000000000000000000..7123a6f01be7a605dc01509570eb6017caddbb32 GIT binary patch literal 188 zcmeAS@N?(olHy`uVBq!ia0vp^?m(=;!3HGP2tA(wq}Y|gW!U_%O?XxI14-? zi-9_>gD|6$#_S59AbW|YuPgg~9u8r7h2v{Jodybddb&7 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -