From 60e18aa0451229d5f112747f38ed9ae2e0cdb29b Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Mon, 26 Sep 2016 17:02:55 +0200 Subject: [PATCH 01/14] similar videos scroll bug workaround --- .../org/schabi/newpipe/ChannelActivity.java | 3 +- .../detail/VideoItemDetailFragment.java | 334 +++++++++--------- .../newpipe/info_list/InfoItemBuilder.java | 174 +++++++++ .../newpipe/info_list/InfoListAdapter.java | 131 +------ .../SearchInfoItemFragment.java | 3 +- .../layout-v18/fragment_videoitem_detail.xml | 5 +- .../res/layout/fragment_videoitem_detail.xml | 5 +- 7 files changed, 351 insertions(+), 304 deletions(-) create mode 100644 app/src/main/java/org/schabi/newpipe/info_list/InfoItemBuilder.java diff --git a/app/src/main/java/org/schabi/newpipe/ChannelActivity.java b/app/src/main/java/org/schabi/newpipe/ChannelActivity.java index d5e9b31bb..e5902897d 100644 --- a/app/src/main/java/org/schabi/newpipe/ChannelActivity.java +++ b/app/src/main/java/org/schabi/newpipe/ChannelActivity.java @@ -26,6 +26,7 @@ import org.schabi.newpipe.extractor.ExtractionException; import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ServiceList; import org.schabi.newpipe.extractor.StreamingService; +import org.schabi.newpipe.info_list.InfoItemBuilder; import org.schabi.newpipe.info_list.InfoListAdapter; import org.schabi.newpipe.report.ErrorActivity; @@ -84,7 +85,7 @@ public class ChannelActivity extends AppCompatActivity { final LinearLayoutManager layoutManager = new LinearLayoutManager(this); recyclerView.setLayoutManager(layoutManager); recyclerView.setAdapter(infoListAdapter); - infoListAdapter.setOnItemSelectedListener(new InfoListAdapter.OnItemSelectedListener() { + infoListAdapter.setOnItemSelectedListener(new InfoItemBuilder.OnItemSelectedListener() { @Override public void selected(String url) { Intent detailIntent = new Intent(ChannelActivity.this, VideoItemDetailActivity.class); diff --git a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java index c22b82c93..3709ebe39 100644 --- a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java @@ -14,7 +14,6 @@ import android.support.design.widget.FloatingActionButton; import android.support.v4.app.Fragment; import android.support.v7.app.AlertDialog; import android.support.v7.app.AppCompatActivity; -import android.support.v7.widget.LinearLayoutManager; import android.support.v7.widget.RecyclerView; import android.text.Html; import android.text.method.LinkMovementMethod; @@ -27,6 +26,7 @@ import android.view.View; import android.view.ViewGroup; import android.widget.Button; import android.widget.ImageView; +import android.widget.LinearLayout; import android.widget.ProgressBar; import android.widget.RelativeLayout; import android.widget.TextView; @@ -43,6 +43,8 @@ import java.util.Vector; import org.schabi.newpipe.ActivityCommunicator; import org.schabi.newpipe.ChannelActivity; +import org.schabi.newpipe.extractor.StreamPreviewInfo; +import org.schabi.newpipe.info_list.InfoItemBuilder; import org.schabi.newpipe.report.ErrorActivity; import org.schabi.newpipe.ImageErrorLoadingListener; import org.schabi.newpipe.Localization; @@ -53,7 +55,6 @@ import org.schabi.newpipe.extractor.MediaFormat; import org.schabi.newpipe.extractor.ServiceList; import org.schabi.newpipe.extractor.StreamInfo; import org.schabi.newpipe.extractor.VideoStream; -import org.schabi.newpipe.info_list.InfoListAdapter; import org.schabi.newpipe.player.BackgroundPlayer; import org.schabi.newpipe.player.PlayVideoActivity; import org.schabi.newpipe.player.ExoPlayerActivity; @@ -110,7 +111,7 @@ public class VideoItemDetailFragment extends Fragment { private DisplayImageOptions displayImageOptions = new DisplayImageOptions.Builder().cacheInMemory(true).build(); - private InfoListAdapter similarStreamsAdapter = null; + private InfoItemBuilder infoItemBuilder = null; public interface OnInvokeCreateOptionsMenuListener { void createOptionsMenu(); @@ -119,183 +120,173 @@ public class VideoItemDetailFragment extends Fragment { private OnInvokeCreateOptionsMenuListener onInvokeCreateOptionsMenuListener; private void updateInfo(final StreamInfo info) { - try { - Activity a = getActivity(); + Activity a = getActivity(); - RelativeLayout textContentLayout = - (RelativeLayout) activity.findViewById(R.id.detail_text_content_layout); - final TextView videoTitleView = - (TextView) activity.findViewById(R.id.detail_video_title_view); - TextView uploaderView = (TextView) activity.findViewById(R.id.detail_uploader_view); - TextView viewCountView = (TextView) activity.findViewById(R.id.detail_view_count_view); - TextView thumbsUpView = (TextView) activity.findViewById(R.id.detail_thumbs_up_count_view); - TextView thumbsDownView = - (TextView) activity.findViewById(R.id.detail_thumbs_down_count_view); - TextView uploadDateView = (TextView) activity.findViewById(R.id.detail_upload_date_view); - TextView descriptionView = (TextView) activity.findViewById(R.id.detail_description_view); - RecyclerView nextStreamView = - (RecyclerView) activity.findViewById(R.id.detail_next_stream_content); - RelativeLayout nextVideoRootFrame = - (RelativeLayout) activity.findViewById(R.id.detail_next_stream_root_layout); - TextView similarTitle = (TextView) activity.findViewById(R.id.detail_similar_title); - Button backgroundButton = (Button) - activity.findViewById(R.id.detail_stream_thumbnail_window_background_button); - View topView = activity.findViewById(R.id.detailTopView); - Button channelButton = (Button) activity.findViewById(R.id.channel_button); + RelativeLayout textContentLayout = + (RelativeLayout) activity.findViewById(R.id.detail_text_content_layout); + final TextView videoTitleView = + (TextView) activity.findViewById(R.id.detail_video_title_view); + TextView uploaderView = (TextView) activity.findViewById(R.id.detail_uploader_view); + TextView viewCountView = (TextView) activity.findViewById(R.id.detail_view_count_view); + TextView thumbsUpView = (TextView) activity.findViewById(R.id.detail_thumbs_up_count_view); + TextView thumbsDownView = + (TextView) activity.findViewById(R.id.detail_thumbs_down_count_view); + TextView uploadDateView = (TextView) activity.findViewById(R.id.detail_upload_date_view); + TextView descriptionView = (TextView) activity.findViewById(R.id.detail_description_view); + RecyclerView nextStreamView = + (RecyclerView) activity.findViewById(R.id.detail_next_stream_content); + RelativeLayout nextVideoRootFrame = + (RelativeLayout) activity.findViewById(R.id.detail_next_stream_root_layout); + TextView similarTitle = (TextView) activity.findViewById(R.id.detail_similar_title); + Button backgroundButton = (Button) + activity.findViewById(R.id.detail_stream_thumbnail_window_background_button); + View topView = activity.findViewById(R.id.detailTopView); + Button channelButton = (Button) activity.findViewById(R.id.channel_button); - progressBar.setVisibility(View.GONE); - if(info.next_video != null) { - InfoListAdapter adapter = new InfoListAdapter(a, rootView); - nextStreamView.setAdapter(adapter); - nextStreamView.setLayoutManager(new LinearLayoutManager(a)); - adapter.setOnItemSelectedListener(new InfoListAdapter.OnItemSelectedListener() { - @Override - public void selected(String url) { - openStreamUrl(url); - } - }); - } else { - nextStreamView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); - } - - - textContentLayout.setVisibility(View.VISIBLE); - if (android.os.Build.VERSION.SDK_INT < 18) { - playVideoButton.setVisibility(View.VISIBLE); - } else { - ImageView playArrowView = (ImageView) activity.findViewById(R.id.play_arrow_view); - playArrowView.setVisibility(View.VISIBLE); - } - - if (!showNextStreamItem) { - nextVideoRootFrame.setVisibility(View.GONE); - similarTitle.setVisibility(View.GONE); - } - - videoTitleView.setText(info.title); - - topView.setOnTouchListener(new View.OnTouchListener() { + progressBar.setVisibility(View.GONE); + if(info.next_video != null) { + infoItemBuilder.setOnItemSelectedListener(new InfoItemBuilder.OnItemSelectedListener() { @Override - public boolean onTouch(View v, MotionEvent event) { - if (event.getAction() == android.view.MotionEvent.ACTION_UP) { - ImageView arrow = (ImageView) activity.findViewById(R.id.toggle_description_view); - View extra = activity.findViewById(R.id.detailExtraView); - if (extra.getVisibility() == View.VISIBLE) { - extra.setVisibility(View.GONE); - arrow.setImageResource(R.drawable.arrow_down); - } else { - extra.setVisibility(View.VISIBLE); - arrow.setImageResource(R.drawable.arrow_up); - } - } - return true; + public void selected(String url) { + openStreamUrl(url); } }); + } else { + nextStreamView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); + } - // Since newpipe is designed to work even if certain information is not available, - // the UI has to react on missing information. - videoTitleView.setText(info.title); - if(!info.uploader.isEmpty()) { - uploaderView.setText(info.uploader); - } else { - activity.findViewById(R.id.detail_uploader_view).setVisibility(View.GONE); - } - if(info.view_count >= 0) { - viewCountView.setText(Localization.localizeViewCount(info.view_count, a)); - } else { - viewCountView.setVisibility(View.GONE); - } - if(info.dislike_count >= 0) { - thumbsDownView.setText(Localization.localizeNumber(info.dislike_count, a)); - } else { - thumbsDownView.setVisibility(View.INVISIBLE); - activity.findViewById(R.id.detail_thumbs_down_count_view).setVisibility(View.GONE); - } - if(info.like_count >= 0) { - thumbsUpView.setText(Localization.localizeNumber(info.like_count, a)); - } else { - thumbsUpView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_thumbs_up_img_view).setVisibility(View.GONE); - thumbsDownView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_thumbs_down_img_view).setVisibility(View.GONE); - } - if(!info.upload_date.isEmpty()) { - uploadDateView.setText(Localization.localizeDate(info.upload_date, a)); - } else { - uploadDateView.setVisibility(View.GONE); - } - if(!info.description.isEmpty()) { - descriptionView.setText(Html.fromHtml(info.description)); - } else { - descriptionView.setVisibility(View.GONE); - } + textContentLayout.setVisibility(View.VISIBLE); + if (android.os.Build.VERSION.SDK_INT < 18) { + playVideoButton.setVisibility(View.VISIBLE); + } else { + ImageView playArrowView = (ImageView) activity.findViewById(R.id.play_arrow_view); + playArrowView.setVisibility(View.VISIBLE); + } - descriptionView.setMovementMethod(LinkMovementMethod.getInstance()); + if (!showNextStreamItem) { + nextVideoRootFrame.setVisibility(View.GONE); + similarTitle.setVisibility(View.GONE); + } - // parse streams - Vector streamsToUse = new Vector<>(); - for (VideoStream i : info.video_streams) { - if (useStream(i, streamsToUse)) { - streamsToUse.add(i); - } - } + videoTitleView.setText(info.title); - textContentLayout.setVisibility(View.VISIBLE); - - if(info.next_video == null) { - activity.findViewById(R.id.detail_next_stream_title).setVisibility(View.GONE); - } - - if(info.related_streams != null && !info.related_streams.isEmpty()) { - initSimilarVideos(info); - } else { - activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); - activity.findViewById(R.id.similar_streams_view).setVisibility(View.GONE); - } - - setupActionBarHandler(info); - - if(autoPlayEnabled) { - playVideo(info); - } - - if (android.os.Build.VERSION.SDK_INT < 18) { - playVideoButton.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - playVideo(info); + topView.setOnTouchListener(new View.OnTouchListener() { + @Override + public boolean onTouch(View v, MotionEvent event) { + if (event.getAction() == android.view.MotionEvent.ACTION_UP) { + ImageView arrow = (ImageView) activity.findViewById(R.id.toggle_description_view); + View extra = activity.findViewById(R.id.detailExtraView); + if (extra.getVisibility() == View.VISIBLE) { + extra.setVisibility(View.GONE); + arrow.setImageResource(R.drawable.arrow_down); + } else { + extra.setVisibility(View.VISIBLE); + arrow.setImageResource(R.drawable.arrow_up); } - }); + } + return true; } + }); - backgroundButton.setOnClickListener(new View.OnClickListener() { + // Since newpipe is designed to work even if certain information is not available, + // the UI has to react on missing information. + videoTitleView.setText(info.title); + if(!info.uploader.isEmpty()) { + uploaderView.setText(info.uploader); + } else { + activity.findViewById(R.id.detail_uploader_view).setVisibility(View.GONE); + } + if(info.view_count >= 0) { + viewCountView.setText(Localization.localizeViewCount(info.view_count, a)); + } else { + viewCountView.setVisibility(View.GONE); + } + if(info.dislike_count >= 0) { + thumbsDownView.setText(Localization.localizeNumber(info.dislike_count, a)); + } else { + thumbsDownView.setVisibility(View.INVISIBLE); + activity.findViewById(R.id.detail_thumbs_down_count_view).setVisibility(View.GONE); + } + if(info.like_count >= 0) { + thumbsUpView.setText(Localization.localizeNumber(info.like_count, a)); + } else { + thumbsUpView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_thumbs_up_img_view).setVisibility(View.GONE); + thumbsDownView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_thumbs_down_img_view).setVisibility(View.GONE); + } + if(!info.upload_date.isEmpty()) { + uploadDateView.setText(Localization.localizeDate(info.upload_date, a)); + } else { + uploadDateView.setVisibility(View.GONE); + } + if(!info.description.isEmpty()) { + descriptionView.setText(Html.fromHtml(info.description)); + } else { + descriptionView.setVisibility(View.GONE); + } + + descriptionView.setMovementMethod(LinkMovementMethod.getInstance()); + + // parse streams + Vector streamsToUse = new Vector<>(); + for (VideoStream i : info.video_streams) { + if (useStream(i, streamsToUse)) { + streamsToUse.add(i); + } + } + + textContentLayout.setVisibility(View.VISIBLE); + + if(info.next_video == null) { + activity.findViewById(R.id.detail_next_stream_title).setVisibility(View.GONE); + } + + if(info.related_streams != null && !info.related_streams.isEmpty()) { + initSimilarVideos(info); + } else { + activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); + activity.findViewById(R.id.similar_streams_view).setVisibility(View.GONE); + } + + setupActionBarHandler(info); + + if(autoPlayEnabled) { + playVideo(info); + } + + if (android.os.Build.VERSION.SDK_INT < 18) { + playVideoButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { playVideo(info); } }); - - if(info.channel_url != null && info.channel_url != "") { - channelButton.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View view) { - Intent i = new Intent(activity, ChannelActivity.class); - i.putExtra(ChannelActivity.CHANNEL_URL, info.channel_url); - i.putExtra(ChannelActivity.SERVICE_ID, info.service_id); - startActivity(i); - } - }); - } else { - channelButton.setVisibility(Button.GONE); - } - - initThumbnailViews(info); - - } catch (java.lang.NullPointerException e) { - Log.w(TAG, "updateInfo(): Fragment closed before thread ended work... or else"); - e.printStackTrace(); } + + backgroundButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + playVideo(info); + } + }); + + if(info.channel_url != null && info.channel_url != "") { + channelButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + Intent i = new Intent(activity, ChannelActivity.class); + i.putExtra(ChannelActivity.CHANNEL_URL, info.channel_url); + i.putExtra(ChannelActivity.SERVICE_ID, info.service_id); + startActivity(i); + } + }); + } else { + channelButton.setVisibility(Button.GONE); + } + + initThumbnailViews(info); } private void initThumbnailViews(final StreamInfo info) { @@ -527,7 +518,10 @@ public class VideoItemDetailFragment extends Fragment { } private void initSimilarVideos(final StreamInfo info) { - similarStreamsAdapter.addStreamItemList(info.related_streams); + LinearLayout similarLayout = (LinearLayout) activity.findViewById(R.id.similar_streams_view); + for (final StreamPreviewInfo item : info.related_streams) { + similarLayout.addView(infoItemBuilder.buildView(similarLayout, item)); + } } private void onErrorBlockedByGema() { @@ -640,6 +634,9 @@ public class VideoItemDetailFragment extends Fragment { public void onActivityCreated(Bundle savedInstanceBundle) { super.onActivityCreated(savedInstanceBundle); Activity a = getActivity(); + + infoItemBuilder = new InfoItemBuilder(a, a.findViewById(android.R.id.content)); + if (android.os.Build.VERSION.SDK_INT < 18) { playVideoButton = (FloatingActionButton) a.findViewById(R.id.play_video_button); } @@ -681,17 +678,6 @@ public class VideoItemDetailFragment extends Fragment { } }); } - - similarStreamsAdapter = new InfoListAdapter(getActivity(), rootView); - RecyclerView rv = (RecyclerView) getActivity().findViewById(R.id.similar_streams_view); - rv.setLayoutManager(new LinearLayoutManager(getActivity())); - rv.setAdapter(similarStreamsAdapter); - similarStreamsAdapter.setOnItemSelectedListener(new InfoListAdapter.OnItemSelectedListener() { - @Override - public void selected(String url) { - openStreamUrl(url); - } - }); } } diff --git a/app/src/main/java/org/schabi/newpipe/info_list/InfoItemBuilder.java b/app/src/main/java/org/schabi/newpipe/info_list/InfoItemBuilder.java new file mode 100644 index 000000000..11ceca08d --- /dev/null +++ b/app/src/main/java/org/schabi/newpipe/info_list/InfoItemBuilder.java @@ -0,0 +1,174 @@ +package org.schabi.newpipe.info_list; + +import android.app.Activity; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import com.nostra13.universalimageloader.core.DisplayImageOptions; +import com.nostra13.universalimageloader.core.ImageLoader; + +import org.schabi.newpipe.ImageErrorLoadingListener; +import org.schabi.newpipe.R; +import org.schabi.newpipe.extractor.AbstractVideoInfo; +import org.schabi.newpipe.extractor.StreamPreviewInfo; + +/** + * Created by Christian Schabesberger on 26.09.16. + * + * Copyright (C) Christian Schabesberger 2016 + * InfoItemBuilder.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 InfoItemBuilder { + + public interface OnItemSelectedListener { + void selected(String url); + } + + private Activity activity = null; + private View rootView = null; + private ImageLoader imageLoader = ImageLoader.getInstance(); + private DisplayImageOptions displayImageOptions = + new DisplayImageOptions.Builder().cacheInMemory(true).build(); + private OnItemSelectedListener onItemSelectedListener; + + public InfoItemBuilder(Activity a, View rootView) { + activity = a; + this.rootView = rootView; + } + + public void setOnItemSelectedListener(OnItemSelectedListener onItemSelectedListener) { + this.onItemSelectedListener = onItemSelectedListener; + } + + public void buildByHolder(InfoItemHolder holder, final StreamPreviewInfo info) { + // fill holder with information + holder.itemVideoTitleView.setText(info.title); + if(info.uploader != null && !info.uploader.isEmpty()) { + holder.itemUploaderView.setText(info.uploader); + } else { + holder.itemUploaderView.setVisibility(View.INVISIBLE); + } + if(info.duration > 0) { + holder.itemDurationView.setText(getDurationString(info.duration)); + } else { + if(info.stream_type == AbstractVideoInfo.StreamType.LIVE_STREAM) { + holder.itemDurationView.setText(R.string.duration_live); + } else { + holder.itemDurationView.setVisibility(View.GONE); + } + } + if(info.view_count >= 0) { + holder.itemViewCountView.setText(shortViewCount(info.view_count)); + } else { + holder.itemViewCountView.setVisibility(View.GONE); + } + if(info.upload_date != null && !info.upload_date.isEmpty()) { + holder.itemUploadDateView.setText(info.upload_date + " • "); + } + + holder.itemThumbnailView.setImageResource(R.drawable.dummy_thumbnail); + if(info.thumbnail_url != null && !info.thumbnail_url.isEmpty()) { + imageLoader.displayImage(info.thumbnail_url, + holder.itemThumbnailView, + displayImageOptions, + new ImageErrorLoadingListener(activity, rootView, info.service_id)); + } + + holder.itemButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + onItemSelectedListener.selected(info.webpage_url); + } + }); + } + + public View buildView(ViewGroup parent, final StreamPreviewInfo info) { + View streamPreviewView = LayoutInflater.from(parent.getContext()) + .inflate(R.layout.video_item, parent, false); + InfoItemHolder holder = new InfoItemHolder(streamPreviewView); + buildByHolder(holder, info); + return streamPreviewView; + } + + + public static String shortViewCount(Long viewCount){ + if(viewCount >= 1000000000){ + return Long.toString(viewCount/1000000000)+"B views"; + }else if(viewCount>=1000000){ + return Long.toString(viewCount/1000000)+"M views"; + }else if(viewCount>=1000){ + return Long.toString(viewCount/1000)+"K views"; + }else { + return Long.toString(viewCount)+" views"; + } + } + + public static String getDurationString(int duration) { + String output = ""; + int days = duration / (24 * 60 * 60); /* greater than a day */ + duration %= (24 * 60 * 60); + int hours = duration / (60 * 60); /* greater than an hour */ + duration %= (60 * 60); + int minutes = duration / 60; + int seconds = duration % 60; + + //handle days + if(days > 0) { + output = Integer.toString(days) + ":"; + } + // handle hours + if(hours > 0 || !output.isEmpty()) { + if(hours > 0) { + if(hours >= 10 || output.isEmpty()) { + output += Integer.toString(hours); + } else { + output += "0" + Integer.toString(hours); + } + } else { + output += "00"; + } + output += ":"; + } + //handle minutes + if(minutes > 0 || !output.isEmpty()) { + if(minutes > 0) { + if(minutes >= 10 || output.isEmpty()) { + output += Integer.toString(minutes); + } else { + output += "0" + Integer.toString(minutes); + } + } else { + output += "00"; + } + output += ":"; + } + + //handle seconds + if(output.isEmpty()) { + output += "0:"; + } + + if(seconds >= 10) { + output += Integer.toString(seconds); + } else { + output += "0" + Integer.toString(seconds); + } + + return output; + } +} diff --git a/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java b/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java index ba23d95ba..13a8d821a 100644 --- a/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java +++ b/app/src/main/java/org/schabi/newpipe/info_list/InfoListAdapter.java @@ -39,27 +39,16 @@ import java.util.Vector; public class InfoListAdapter extends RecyclerView.Adapter { - public interface OnItemSelectedListener { - void selected(String url); - } - - private Activity activity = null; - private View rootView = null; - private List streamList = new Vector<>(); - private ImageLoader imageLoader = ImageLoader.getInstance(); - private DisplayImageOptions displayImageOptions = - new DisplayImageOptions.Builder().cacheInMemory(true).build(); - private OnItemSelectedListener onItemSelectedListener; - - + InfoItemBuilder infoItemBuilder = null; + List streamList = new Vector<>(); public InfoListAdapter(Activity a, View rootView) { - activity = a; - this.rootView = rootView; + infoItemBuilder = new InfoItemBuilder(a, rootView); } - public void setOnItemSelectedListener(OnItemSelectedListener onItemSelectedListener) { - this.onItemSelectedListener = onItemSelectedListener; + public void setOnItemSelectedListener + (InfoItemBuilder.OnItemSelectedListener onItemSelectedListener) { + infoItemBuilder.setOnItemSelectedListener(onItemSelectedListener); } public void addStreamItemList(List videos) { @@ -89,112 +78,6 @@ public class InfoListAdapter extends RecyclerView.Adapter { @Override public void onBindViewHolder(InfoItemHolder holder, int i) { - final StreamPreviewInfo info = streamList.get(i); - // fill holder with information - holder.itemVideoTitleView.setText(info.title); - if(info.uploader != null && !info.uploader.isEmpty()) { - holder.itemUploaderView.setText(info.uploader); - } else { - holder.itemUploaderView.setVisibility(View.INVISIBLE); - } - if(info.duration > 0) { - holder.itemDurationView.setText(getDurationString(info.duration)); - } else { - if(info.stream_type == AbstractVideoInfo.StreamType.LIVE_STREAM) { - holder.itemDurationView.setText(R.string.duration_live); - } else { - holder.itemDurationView.setVisibility(View.GONE); - } - } - if(info.view_count >= 0) { - holder.itemViewCountView.setText(shortViewCount(info.view_count)); - } else { - holder.itemViewCountView.setVisibility(View.GONE); - } - if(info.upload_date != null && !info.upload_date.isEmpty()) { - holder.itemUploadDateView.setText(info.upload_date + " • "); - } - - holder.itemThumbnailView.setImageResource(R.drawable.dummy_thumbnail); - if(info.thumbnail_url != null && !info.thumbnail_url.isEmpty()) { - imageLoader.displayImage(info.thumbnail_url, - holder.itemThumbnailView, - displayImageOptions, - new ImageErrorLoadingListener(activity, rootView, info.service_id)); - } - - holder.itemButton.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View view) { - onItemSelectedListener.selected(info.webpage_url); - } - }); - } - - - public static String shortViewCount(Long viewCount){ - if(viewCount >= 1000000000){ - return Long.toString(viewCount/1000000000)+"B views"; - }else if(viewCount>=1000000){ - return Long.toString(viewCount/1000000)+"M views"; - }else if(viewCount>=1000){ - return Long.toString(viewCount/1000)+"K views"; - }else { - return Long.toString(viewCount)+" views"; - } - } - - public static String getDurationString(int duration) { - String output = ""; - int days = duration / (24 * 60 * 60); /* greater than a day */ - duration %= (24 * 60 * 60); - int hours = duration / (60 * 60); /* greater than an hour */ - duration %= (60 * 60); - int minutes = duration / 60; - int seconds = duration % 60; - - //handle days - if(days > 0) { - output = Integer.toString(days) + ":"; - } - // handle hours - if(hours > 0 || !output.isEmpty()) { - if(hours > 0) { - if(hours >= 10 || output.isEmpty()) { - output += Integer.toString(hours); - } else { - output += "0" + Integer.toString(hours); - } - } else { - output += "00"; - } - output += ":"; - } - //handle minutes - if(minutes > 0 || !output.isEmpty()) { - if(minutes > 0) { - if(minutes >= 10 || output.isEmpty()) { - output += Integer.toString(minutes); - } else { - output += "0" + Integer.toString(minutes); - } - } else { - output += "00"; - } - output += ":"; - } - - //handle seconds - if(output.isEmpty()) { - output += "0:"; - } - - if(seconds >= 10) { - output += Integer.toString(seconds); - } else { - output += "0" + Integer.toString(seconds); - } - - return output; + infoItemBuilder.buildByHolder(holder, streamList.get(i)); } } diff --git a/app/src/main/java/org/schabi/newpipe/search_fragment/SearchInfoItemFragment.java b/app/src/main/java/org/schabi/newpipe/search_fragment/SearchInfoItemFragment.java index fbe7546e6..9f893c0c6 100644 --- a/app/src/main/java/org/schabi/newpipe/search_fragment/SearchInfoItemFragment.java +++ b/app/src/main/java/org/schabi/newpipe/search_fragment/SearchInfoItemFragment.java @@ -18,6 +18,7 @@ import android.view.inputmethod.InputMethodManager; import android.widget.ProgressBar; import android.widget.Toast; +import org.schabi.newpipe.info_list.InfoItemBuilder; import org.schabi.newpipe.report.ErrorActivity; import org.schabi.newpipe.R; import org.schabi.newpipe.detail.VideoItemDetailActivity; @@ -189,7 +190,7 @@ public class SearchInfoItemFragment extends Fragment { infoListAdapter = new InfoListAdapter(getActivity(), getActivity().findViewById(android.R.id.content)); - infoListAdapter.setOnItemSelectedListener(new InfoListAdapter.OnItemSelectedListener() { + infoListAdapter.setOnItemSelectedListener(new InfoItemBuilder.OnItemSelectedListener() { @Override public void selected(String url) { Intent i = new Intent(getActivity(), VideoItemDetailActivity.class); diff --git a/app/src/main/res/layout-v18/fragment_videoitem_detail.xml b/app/src/main/res/layout-v18/fragment_videoitem_detail.xml index 3cd76a5b0..003bb393e 100644 --- a/app/src/main/res/layout-v18/fragment_videoitem_detail.xml +++ b/app/src/main/res/layout-v18/fragment_videoitem_detail.xml @@ -265,12 +265,13 @@ android:text="@string/similar_videos_btn_text" android:layout_below="@id/detail_next_stream_content" android:textAllCaps="true" /> - + android:layout_below="@id/detail_similar_title"> + diff --git a/app/src/main/res/layout/fragment_videoitem_detail.xml b/app/src/main/res/layout/fragment_videoitem_detail.xml index 9b3d9856c..526840311 100644 --- a/app/src/main/res/layout/fragment_videoitem_detail.xml +++ b/app/src/main/res/layout/fragment_videoitem_detail.xml @@ -267,12 +267,13 @@ android:text="@string/similar_videos_btn_text" android:layout_below="@id/detail_next_stream_content" android:textAllCaps="true" /> - + android:layout_below="@id/detail_similar_title"> + From 80b3b8ac0f9209301d2ae35312318a82d286bd5a Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Mon, 26 Sep 2016 17:04:54 +0200 Subject: [PATCH 02/14] change readme layout --- README.md | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 190cb03b5..a6dcb30a7 100644 --- a/README.md +++ b/README.md @@ -4,21 +4,19 @@ WARNING: PUTTING NEWPIPE OR ANY FORK OF IT INTO GOOGLE PLAYSTORE VIOLATES THEIR NewPipe: A free lightweight Youtube frontend for Android. [![NewPipe](app/src/main/res/mipmap-xhdpi/ic_launcher.png)](https://newpipe.schabi.org) +[![F-Droid](https://f-droid.org/wiki/images/0/06/F-Droid-button_get-it-on.png)](https://f-droid.org/repository/browse/?fdfilter=newpipe&fdid=org.schabi.newpipe) + Project status: [![Translation Status](https://hosted.weblate.org/widgets/NewPipe/-/svg-badge.svg)](https://hosted.weblate.org/engage/NewPipe/) [![Build Status](https://travis-ci.org/theScrabi/NewPipe.svg)](https://travis-ci.org/theScrabi/NewPipe) -## Get NewPipe - -[![F-Droid](https://f-droid.org/wiki/images/0/06/F-Droid-button_get-it-on.png)](https://f-droid.org/repository/browse/?fdfilter=newpipe&fdid=org.schabi.newpipe) - ## Donate ![Bitcoin](https://bitcoin.org/img/icons/logotop.svg) -`16A9J59ahMRqkLSZjhYj33n9j3fMztFxnh` - ![BitcoinQR](assets/16A9J59ahMRqkLSZjhYj33n9j3fMztFxnh.png) +`16A9J59ahMRqkLSZjhYj33n9j3fMztFxnh` + ## Screenshots [](screenshots/screenshot_1.png) From abfdcea4db96dbb9f2f96bed24d2286bc3fdcb18 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Mon, 26 Sep 2016 17:32:03 +0200 Subject: [PATCH 03/14] moved on to 0.8.5 --- app/build.gradle | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index c371a3712..d161186fc 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,8 +8,8 @@ android { applicationId "org.schabi.newpipe" minSdkVersion 15 targetSdkVersion 24 - versionCode 18 - versionName "0.8.0" + versionCode 19 + versionName "0.8.5" } buildTypes { release { From 931f34d2fd126d5c71528494ffb013fb80bac13b Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Mon, 26 Sep 2016 18:01:39 +0200 Subject: [PATCH 04/14] fixed related videos nullpointer exception --- .../newpipe/detail/VideoItemDetailFragment.java | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java index 3709ebe39..626c52ba3 100644 --- a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java @@ -145,12 +145,8 @@ public class VideoItemDetailFragment extends Fragment { progressBar.setVisibility(View.GONE); if(info.next_video != null) { - infoItemBuilder.setOnItemSelectedListener(new InfoItemBuilder.OnItemSelectedListener() { - @Override - public void selected(String url) { - openStreamUrl(url); - } - }); + // todo: activate this function or remove it + nextStreamView.setVisibility(View.GONE); } else { nextStreamView.setVisibility(View.GONE); activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); @@ -522,6 +518,12 @@ public class VideoItemDetailFragment extends Fragment { for (final StreamPreviewInfo item : info.related_streams) { similarLayout.addView(infoItemBuilder.buildView(similarLayout, item)); } + infoItemBuilder.setOnItemSelectedListener(new InfoItemBuilder.OnItemSelectedListener() { + @Override + public void selected(String url) { + openStreamUrl(url); + } + }); } private void onErrorBlockedByGema() { From 2b89e24a4b191345d8f733513bcf9adaa7338260 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Mon, 26 Sep 2016 20:18:32 +0200 Subject: [PATCH 05/14] make download dialog use radio button --- .../newpipe/download/DownloadDialog.java | 20 ++++++++++--------- app/src/main/res/layout/dialog_url.xml | 10 ++++++++-- 2 files changed, 19 insertions(+), 11 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java b/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java index c7018ae1d..57dd4bd85 100644 --- a/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java +++ b/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java @@ -19,8 +19,8 @@ import android.view.LayoutInflater; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; -import android.widget.CheckBox; import android.widget.EditText; +import android.widget.RadioButton; import android.widget.SeekBar; import android.widget.TextView; @@ -175,13 +175,15 @@ public class DownloadDialog extends DialogFragment { protected void checkDownloadOptions(){ View view = getView(); Bundle arguments = getArguments(); - CheckBox audio = (CheckBox) view.findViewById(R.id.audio); - CheckBox video = (CheckBox) view.findViewById(R.id.video); + RadioButton audioButton = (RadioButton) view.findViewById(R.id.audio_button); + RadioButton videoButton = (RadioButton) view.findViewById(R.id.video_button); if(arguments.getString(AUDIO_URL) == null) { - audio.setVisibility(View.GONE); + audioButton.setVisibility(View.GONE); + videoButton.setChecked(true); } else if(arguments.getString(VIDEO_URL) == null) { - video.setVisibility(View.GONE); + videoButton.setVisibility(View.GONE); + audioButton.setChecked(true); } } @@ -211,15 +213,15 @@ public class DownloadDialog extends DialogFragment { Bundle arguments = getArguments(); final EditText name = (EditText) view.findViewById(R.id.file_name); final SeekBar threads = (SeekBar) view.findViewById(R.id.threads); - CheckBox audio = (CheckBox) view.findViewById(R.id.audio); - CheckBox video = (CheckBox) view.findViewById(R.id.video); + RadioButton audioButton = (RadioButton) view.findViewById(R.id.audio_button); + RadioButton videoButton = (RadioButton) view.findViewById(R.id.video_button); String fName = name.getText().toString().trim(); // todo: add timeout? would be bad if the thread gets locked dueto this. while (mBinder == null); - if(audio.isChecked()){ + if(audioButton.isChecked()){ int res = mManager.startMission( arguments.getString(AUDIO_URL), fName + arguments.getString(FILE_SUFFIX_AUDIO), @@ -227,7 +229,7 @@ public class DownloadDialog extends DialogFragment { mBinder.onMissionAdded(mManager.getMission(res)); } - if(video.isChecked()){ + if(videoButton.isChecked()){ int res = mManager.startMission( arguments.getString(VIDEO_URL), fName + arguments.getString(FILE_SUFFIX_VIDEO), diff --git a/app/src/main/res/layout/dialog_url.xml b/app/src/main/res/layout/dialog_url.xml index fb61888fd..33df882be 100644 --- a/app/src/main/res/layout/dialog_url.xml +++ b/app/src/main/res/layout/dialog_url.xml @@ -58,15 +58,21 @@ android:layout_marginBottom="24dp" android:gravity="left" android:orientation="horizontal"> - + - + Date: Tue, 27 Sep 2016 13:43:43 +0200 Subject: [PATCH 06/14] update contribution guidelines --- CONTRIBUTING.md | 34 ++++++++++++++++------------------ 1 file changed, 16 insertions(+), 18 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index e6c3886d6..8dba8a636 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,33 +1,31 @@ -#Contribution +NewPipe contribution guidelines +=============================== -This document contains guidelines on making contributions to NewPipe. +READ THIS GUIDELINES CAREFULLY BEVORE CONTRIBUGING. -## Programming +## Crashreporting -* Follow the [Google Style Guidelines](https://google.github.io/styleguide/javaguide.html) -* Make a new feature on a separate branch, not on the master branch -* Make a [pull request](https://github.com/theScrabi/NewPipe/pulls) if you're done with your changes -* When submitting changes, you agree that your code will be GPLv3 licensed +Do not report crashes in the github issue tracker. NewPipe has an automated crashreport system that will ask you to send a report if a crash occures. -## Commit messages +## Issue reporting/feature request -* The subject line of your commit message shouldn't be longer than 72 characters -* Try to keep each line of your commit message 72 characters to ensure proper - compatibility with all git tools -* [This guide](http://chris.beams.io/posts/git-commit/) goes more in depth on what makes a good commit message +* Search the [existing issues](https://github.com/theScrabi/NewPipe/issues) first to make sure your issue/feature hasn't been reported/requested before +* Check if this issue/feature is already fixed/implemented in the repository +* If you are an android/java developer you are always welcome to fix/implement an issue/a feature yourself ## Translation * NewPipe can be translated on [weblate](https://hosted.weblate.org/projects/newpipe/strings/) -## Issue reporting +## Code contribution -* Search the [existing issues](https://github.com/theScrabi/NewPipe/issues) first to make sure your issue hasn't been reported before -* Check if this issue is already fixed in the repository -* When making bug reports, be sure to tell which version of NewPipe you are using and the steps to reproduce the problem -* Please include a log if you can +* Follow the [Google Style Guidelines](https://google.github.io/styleguide/javaguide.html) +* Make changes on a separate branch, not on the master branch (Featurebranching) +* When submitting changes, you agree that your code will be licensed under GPLv3 +* Please test your code bevore you submit changes!!! ## Communication -* For the time being, [Slack](https://newpipe.slack.com/) is being used for project communication. Ask [me](https://github.com/theScrabi) to sign up. +* I hereby declare our Slack channel as dead!!! There are no plans on building a new chat, but if there is interest on creating one and ceeping it alive, I'd be pleased to create one again. +* If you want to get in contact with me or one of our other contrebutors you can send me an email at tnp(at)schabi.org * Feel free to post suggestions, changes, ideas etc! From 75e28893fb02827cd48c792af07dbcdd8bb26b30 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 14:14:59 +0200 Subject: [PATCH 07/14] update contribution guidelines once again --- CONTRIBUTING.md | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 8dba8a636..f9311621f 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,11 +1,11 @@ NewPipe contribution guidelines =============================== -READ THIS GUIDELINES CAREFULLY BEVORE CONTRIBUGING. +READ THIS GUIDELINES CAREFULLY BEFORE CONTRIBUTING. -## Crashreporting +## Crash reporting -Do not report crashes in the github issue tracker. NewPipe has an automated crashreport system that will ask you to send a report if a crash occures. +Do not report crashes in the GitHub issue tracker. NewPipe has an automated crash report system that will ask you to send a report if a crash occures. ## Issue reporting/feature request @@ -19,13 +19,18 @@ Do not report crashes in the github issue tracker. NewPipe has an automated cras ## Code contribution -* Follow the [Google Style Guidelines](https://google.github.io/styleguide/javaguide.html) -* Make changes on a separate branch, not on the master branch (Featurebranching) +* Stick to NewPipe style guidelines (just look the other code and than do it the same way :) ) +* Do not bring nonfree software/binary blobs into the project (keep it google free) +* Stick to [f-droid contribution guidelines](https://f-droid.org/wiki/page/Inclusion_Policy) +* Make changes on a separate branch, not on the master branch (Feature-branching) * When submitting changes, you agree that your code will be licensed under GPLv3 -* Please test your code bevore you submit changes!!! +* Please test (compile and run) your code before you submit changes!!! +* Try to figure out you selves why CI fails, or why a merge request collides +* Please maintain your code after you contributed it. +* Respond yourselves if someone request changes or notifies issues ## Communication -* I hereby declare our Slack channel as dead!!! There are no plans on building a new chat, but if there is interest on creating one and ceeping it alive, I'd be pleased to create one again. -* If you want to get in contact with me or one of our other contrebutors you can send me an email at tnp(at)schabi.org +* I hereby declare our Slack channel as dead!!! There are no plans on building a new chat, but if there is interest on creating one and keeping it alive, I'd be pleased to create one again. +* If you want to get in contact with me or one of our other contributors you can send me an email at tnp(at)schabi.org * Feel free to post suggestions, changes, ideas etc! From cac360d37b23ecc91368151dd164cfd5ef5ca632 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 14:30:03 +0200 Subject: [PATCH 08/14] add .github folder --- CONTRIBUTING.md => .github/CONTRIBUTING.md | 0 .github/ISSUE_TEMPLATE.md | 1 + .github/PULL_REQUEST_TEAMPLATE.md | 1 + 3 files changed, 2 insertions(+) rename CONTRIBUTING.md => .github/CONTRIBUTING.md (100%) create mode 100644 .github/ISSUE_TEMPLATE.md create mode 100644 .github/PULL_REQUEST_TEAMPLATE.md diff --git a/CONTRIBUTING.md b/.github/CONTRIBUTING.md similarity index 100% rename from CONTRIBUTING.md rename to .github/CONTRIBUTING.md diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md new file mode 100644 index 000000000..fc576aff6 --- /dev/null +++ b/.github/ISSUE_TEMPLATE.md @@ -0,0 +1 @@ +[ ] I carefully reed the [contribution guidelines](https://github.com/TeamNewPipe/NewPipe/blob/HEAD/.github/CONTRIBUTING.md) and agree to them. diff --git a/.github/PULL_REQUEST_TEAMPLATE.md b/.github/PULL_REQUEST_TEAMPLATE.md new file mode 100644 index 000000000..fc576aff6 --- /dev/null +++ b/.github/PULL_REQUEST_TEAMPLATE.md @@ -0,0 +1 @@ +[ ] I carefully reed the [contribution guidelines](https://github.com/TeamNewPipe/NewPipe/blob/HEAD/.github/CONTRIBUTING.md) and agree to them. From efa605700dc6b953287c4fda9853f3c76bc8677c Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 14:33:30 +0200 Subject: [PATCH 09/14] update contributions link in the readme --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index a6dcb30a7..f54fbccea 100644 --- a/README.md +++ b/README.md @@ -64,7 +64,7 @@ Although NewPipe only supports YouTube at the moment, it's designed to support m Whether you have ideas, translation, design changes, code cleaning, or real heavy code changes, help is always welcome. The more is done the better it gets! -If you'd like to get involved, check our [contribution notes](CONTRIBUTING.md). +If you'd like to get involved, check our [contribution notes](.github/CONTRIBUTING.md). ## License [![GNU GPLv3 Image](https://www.gnu.org/graphics/gplv3-127x51.png)](http://www.gnu.org/licenses/gpl-3.0.en.html) From 3b2c0186aa6572c78b774eebcb10d86726e8c033 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 14:58:46 +0200 Subject: [PATCH 10/14] update issue teamplate --- .github/ISSUE_TEMPLATE.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md index fc576aff6..43e8fbc0a 100644 --- a/.github/ISSUE_TEMPLATE.md +++ b/.github/ISSUE_TEMPLATE.md @@ -1 +1,2 @@ -[ ] I carefully reed the [contribution guidelines](https://github.com/TeamNewPipe/NewPipe/blob/HEAD/.github/CONTRIBUTING.md) and agree to them. +- [ ] I carefully reed the [contribution guidelines](https://github.com/TeamNewPipe/NewPipe/blob/HEAD/.github/CONTRIBUTING.md) and agree to them. +- [ ] I checked if the issue/feature exists in the latest version. From ca0d594547142cffc2ac8916bf1bbda39dc0b092 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 20:06:33 +0200 Subject: [PATCH 11/14] cleaning away android stuff from extractor --- .../java/org/schabi/newpipe/extractor/AbstractVideoInfo.java | 3 --- .../main/java/org/schabi/newpipe/extractor/ChannelInfo.java | 2 -- app/src/main/java/org/schabi/newpipe/extractor/Parser.java | 2 -- .../main/java/org/schabi/newpipe/extractor/ServiceList.java | 2 -- .../main/java/org/schabi/newpipe/extractor/StreamInfo.java | 1 - .../extractor/services/youtube/YoutubeChannelExtractor.java | 2 -- .../extractor/services/youtube/YoutubeSearchEngine.java | 5 ----- 7 files changed, 17 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/extractor/AbstractVideoInfo.java b/app/src/main/java/org/schabi/newpipe/extractor/AbstractVideoInfo.java index f14fbf2f2..8c9b28c5e 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/AbstractVideoInfo.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/AbstractVideoInfo.java @@ -1,7 +1,5 @@ package org.schabi.newpipe.extractor; -import android.graphics.Bitmap; - /** * Copyright (C) Christian Schabesberger 2015 * AbstractVideoInfo.java is part of NewPipe. @@ -37,7 +35,6 @@ public abstract class AbstractVideoInfo { public String title = ""; public String uploader = ""; public String thumbnail_url = ""; - public Bitmap thumbnail; public String webpage_url = ""; public String upload_date = ""; public long view_count = -1; diff --git a/app/src/main/java/org/schabi/newpipe/extractor/ChannelInfo.java b/app/src/main/java/org/schabi/newpipe/extractor/ChannelInfo.java index 2f856dac0..941d08564 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/ChannelInfo.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/ChannelInfo.java @@ -1,7 +1,5 @@ package org.schabi.newpipe.extractor; -import android.util.Log; - import java.util.List; import java.util.Vector; diff --git a/app/src/main/java/org/schabi/newpipe/extractor/Parser.java b/app/src/main/java/org/schabi/newpipe/extractor/Parser.java index 211c1ed47..5ed9b8708 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/Parser.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/Parser.java @@ -1,7 +1,5 @@ package org.schabi.newpipe.extractor; -import android.util.Log; - import java.io.UnsupportedEncodingException; import java.net.URLDecoder; import java.util.HashMap; diff --git a/app/src/main/java/org/schabi/newpipe/extractor/ServiceList.java b/app/src/main/java/org/schabi/newpipe/extractor/ServiceList.java index 9571819a9..fd3dc506d 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/ServiceList.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/ServiceList.java @@ -1,7 +1,5 @@ package org.schabi.newpipe.extractor; -import android.util.Log; - import org.schabi.newpipe.extractor.services.youtube.YoutubeService; /** diff --git a/app/src/main/java/org/schabi/newpipe/extractor/StreamInfo.java b/app/src/main/java/org/schabi/newpipe/extractor/StreamInfo.java index 9c710114b..f3fde27ae 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/StreamInfo.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/StreamInfo.java @@ -44,7 +44,6 @@ public class StreamInfo extends AbstractVideoInfo { this.title = avi.title; this.uploader = avi.uploader; this.thumbnail_url = avi.thumbnail_url; - this.thumbnail = avi.thumbnail; this.webpage_url = avi.webpage_url; this.upload_date = avi.upload_date; this.upload_date = avi.upload_date; diff --git a/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractor.java b/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractor.java index a33707d1c..f7f5e4923 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractor.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeChannelExtractor.java @@ -19,8 +19,6 @@ import org.schabi.newpipe.extractor.UrlIdHandler; import java.io.IOException; -import java.util.HashMap; -import java.util.Map; /** * Created by Christian Schabesberger on 25.07.16. diff --git a/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeSearchEngine.java b/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeSearchEngine.java index 5e84eac77..2a361ed7b 100644 --- a/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeSearchEngine.java +++ b/app/src/main/java/org/schabi/newpipe/extractor/services/youtube/YoutubeSearchEngine.java @@ -1,17 +1,12 @@ package org.schabi.newpipe.extractor.services.youtube; -import android.util.Log; - import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; -import org.schabi.newpipe.extractor.AbstractVideoInfo; import org.schabi.newpipe.extractor.Downloader; import org.schabi.newpipe.extractor.ExtractionException; -import org.schabi.newpipe.extractor.Parser; import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.SearchEngine; -import org.schabi.newpipe.extractor.StreamPreviewInfoCollector; import org.schabi.newpipe.extractor.StreamPreviewInfoExtractor; import org.schabi.newpipe.extractor.StreamPreviewInfoSearchCollector; import org.schabi.newpipe.extractor.UrlIdHandler; From 76ba2824a20e54d72926bfaa871ac8858461c4a4 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 20:18:41 +0200 Subject: [PATCH 12/14] stability improvements --- .../detail/VideoItemDetailFragment.java | 244 +++++++++--------- 1 file changed, 124 insertions(+), 120 deletions(-) diff --git a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java index 626c52ba3..bbca4dcae 100644 --- a/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java +++ b/app/src/main/java/org/schabi/newpipe/detail/VideoItemDetailFragment.java @@ -143,146 +143,150 @@ public class VideoItemDetailFragment extends Fragment { View topView = activity.findViewById(R.id.detailTopView); Button channelButton = (Button) activity.findViewById(R.id.channel_button); - progressBar.setVisibility(View.GONE); - if(info.next_video != null) { - // todo: activate this function or remove it - nextStreamView.setVisibility(View.GONE); - } else { - nextStreamView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); - } + // prevents a crash if the activity/fragment was already left when the response came + if(channelButton != null) { - textContentLayout.setVisibility(View.VISIBLE); - if (android.os.Build.VERSION.SDK_INT < 18) { - playVideoButton.setVisibility(View.VISIBLE); - } else { - ImageView playArrowView = (ImageView) activity.findViewById(R.id.play_arrow_view); - playArrowView.setVisibility(View.VISIBLE); - } + progressBar.setVisibility(View.GONE); + if (info.next_video != null) { + // todo: activate this function or remove it + nextStreamView.setVisibility(View.GONE); + } else { + nextStreamView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); + } - if (!showNextStreamItem) { - nextVideoRootFrame.setVisibility(View.GONE); - similarTitle.setVisibility(View.GONE); - } + textContentLayout.setVisibility(View.VISIBLE); + if (android.os.Build.VERSION.SDK_INT < 18) { + playVideoButton.setVisibility(View.VISIBLE); + } else { + ImageView playArrowView = (ImageView) activity.findViewById(R.id.play_arrow_view); + playArrowView.setVisibility(View.VISIBLE); + } - videoTitleView.setText(info.title); + if (!showNextStreamItem) { + nextVideoRootFrame.setVisibility(View.GONE); + similarTitle.setVisibility(View.GONE); + } - topView.setOnTouchListener(new View.OnTouchListener() { - @Override - public boolean onTouch(View v, MotionEvent event) { - if (event.getAction() == android.view.MotionEvent.ACTION_UP) { - ImageView arrow = (ImageView) activity.findViewById(R.id.toggle_description_view); - View extra = activity.findViewById(R.id.detailExtraView); - if (extra.getVisibility() == View.VISIBLE) { - extra.setVisibility(View.GONE); - arrow.setImageResource(R.drawable.arrow_down); - } else { - extra.setVisibility(View.VISIBLE); - arrow.setImageResource(R.drawable.arrow_up); + videoTitleView.setText(info.title); + + topView.setOnTouchListener(new View.OnTouchListener() { + @Override + public boolean onTouch(View v, MotionEvent event) { + if (event.getAction() == android.view.MotionEvent.ACTION_UP) { + ImageView arrow = (ImageView) activity.findViewById(R.id.toggle_description_view); + View extra = activity.findViewById(R.id.detailExtraView); + if (extra.getVisibility() == View.VISIBLE) { + extra.setVisibility(View.GONE); + arrow.setImageResource(R.drawable.arrow_down); + } else { + extra.setVisibility(View.VISIBLE); + arrow.setImageResource(R.drawable.arrow_up); + } } + return true; } - return true; + }); + + // Since newpipe is designed to work even if certain information is not available, + // the UI has to react on missing information. + videoTitleView.setText(info.title); + if (!info.uploader.isEmpty()) { + uploaderView.setText(info.uploader); + } else { + activity.findViewById(R.id.detail_uploader_view).setVisibility(View.GONE); } - }); - - // Since newpipe is designed to work even if certain information is not available, - // the UI has to react on missing information. - videoTitleView.setText(info.title); - if(!info.uploader.isEmpty()) { - uploaderView.setText(info.uploader); - } else { - activity.findViewById(R.id.detail_uploader_view).setVisibility(View.GONE); - } - if(info.view_count >= 0) { - viewCountView.setText(Localization.localizeViewCount(info.view_count, a)); - } else { - viewCountView.setVisibility(View.GONE); - } - if(info.dislike_count >= 0) { - thumbsDownView.setText(Localization.localizeNumber(info.dislike_count, a)); - } else { - thumbsDownView.setVisibility(View.INVISIBLE); - activity.findViewById(R.id.detail_thumbs_down_count_view).setVisibility(View.GONE); - } - if(info.like_count >= 0) { - thumbsUpView.setText(Localization.localizeNumber(info.like_count, a)); - } else { - thumbsUpView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_thumbs_up_img_view).setVisibility(View.GONE); - thumbsDownView.setVisibility(View.GONE); - activity.findViewById(R.id.detail_thumbs_down_img_view).setVisibility(View.GONE); - } - if(!info.upload_date.isEmpty()) { - uploadDateView.setText(Localization.localizeDate(info.upload_date, a)); - } else { - uploadDateView.setVisibility(View.GONE); - } - if(!info.description.isEmpty()) { - descriptionView.setText(Html.fromHtml(info.description)); - } else { - descriptionView.setVisibility(View.GONE); - } - - descriptionView.setMovementMethod(LinkMovementMethod.getInstance()); - - // parse streams - Vector streamsToUse = new Vector<>(); - for (VideoStream i : info.video_streams) { - if (useStream(i, streamsToUse)) { - streamsToUse.add(i); + if (info.view_count >= 0) { + viewCountView.setText(Localization.localizeViewCount(info.view_count, a)); + } else { + viewCountView.setVisibility(View.GONE); + } + if (info.dislike_count >= 0) { + thumbsDownView.setText(Localization.localizeNumber(info.dislike_count, a)); + } else { + thumbsDownView.setVisibility(View.INVISIBLE); + activity.findViewById(R.id.detail_thumbs_down_count_view).setVisibility(View.GONE); + } + if (info.like_count >= 0) { + thumbsUpView.setText(Localization.localizeNumber(info.like_count, a)); + } else { + thumbsUpView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_thumbs_up_img_view).setVisibility(View.GONE); + thumbsDownView.setVisibility(View.GONE); + activity.findViewById(R.id.detail_thumbs_down_img_view).setVisibility(View.GONE); + } + if (!info.upload_date.isEmpty()) { + uploadDateView.setText(Localization.localizeDate(info.upload_date, a)); + } else { + uploadDateView.setVisibility(View.GONE); + } + if (!info.description.isEmpty()) { + descriptionView.setText(Html.fromHtml(info.description)); + } else { + descriptionView.setVisibility(View.GONE); } - } - textContentLayout.setVisibility(View.VISIBLE); + descriptionView.setMovementMethod(LinkMovementMethod.getInstance()); - if(info.next_video == null) { - activity.findViewById(R.id.detail_next_stream_title).setVisibility(View.GONE); - } + // parse streams + Vector streamsToUse = new Vector<>(); + for (VideoStream i : info.video_streams) { + if (useStream(i, streamsToUse)) { + streamsToUse.add(i); + } + } - if(info.related_streams != null && !info.related_streams.isEmpty()) { - initSimilarVideos(info); - } else { - activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); - activity.findViewById(R.id.similar_streams_view).setVisibility(View.GONE); - } + textContentLayout.setVisibility(View.VISIBLE); - setupActionBarHandler(info); + if (info.next_video == null) { + activity.findViewById(R.id.detail_next_stream_title).setVisibility(View.GONE); + } - if(autoPlayEnabled) { - playVideo(info); - } + if (info.related_streams != null && !info.related_streams.isEmpty()) { + initSimilarVideos(info); + } else { + activity.findViewById(R.id.detail_similar_title).setVisibility(View.GONE); + activity.findViewById(R.id.similar_streams_view).setVisibility(View.GONE); + } - if (android.os.Build.VERSION.SDK_INT < 18) { - playVideoButton.setOnClickListener(new View.OnClickListener() { + setupActionBarHandler(info); + + if (autoPlayEnabled) { + playVideo(info); + } + + if (android.os.Build.VERSION.SDK_INT < 18) { + playVideoButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + playVideo(info); + } + }); + } + + backgroundButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { playVideo(info); } }); - } - backgroundButton.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - playVideo(info); + if (info.channel_url != null && info.channel_url != "") { + channelButton.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + Intent i = new Intent(activity, ChannelActivity.class); + i.putExtra(ChannelActivity.CHANNEL_URL, info.channel_url); + i.putExtra(ChannelActivity.SERVICE_ID, info.service_id); + startActivity(i); + } + }); + } else { + channelButton.setVisibility(Button.GONE); } - }); - if(info.channel_url != null && info.channel_url != "") { - channelButton.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View view) { - Intent i = new Intent(activity, ChannelActivity.class); - i.putExtra(ChannelActivity.CHANNEL_URL, info.channel_url); - i.putExtra(ChannelActivity.SERVICE_ID, info.service_id); - startActivity(i); - } - }); - } else { - channelButton.setVisibility(Button.GONE); + initThumbnailViews(info); } - - initThumbnailViews(info); } private void initThumbnailViews(final StreamInfo info) { @@ -290,7 +294,7 @@ public class VideoItemDetailFragment extends Fragment { ImageView uploaderThumb = (ImageView) activity.findViewById(R.id.detail_uploader_thumbnail_view); - if(info.thumbnail_url != null && !info.thumbnail_url.isEmpty()) { + if (info.thumbnail_url != null && !info.thumbnail_url.isEmpty()) { imageLoader.displayImage(info.thumbnail_url, videoThumbnailView, displayImageOptions, new ImageLoadingListener() { @Override @@ -318,7 +322,7 @@ public class VideoItemDetailFragment extends Fragment { } else { videoThumbnailView.setImageResource(R.drawable.dummy_thumbnail_dark); } - if(info.uploader_thumbnail_url != null && !info.uploader_thumbnail_url.isEmpty()) { + if (info.uploader_thumbnail_url != null && !info.uploader_thumbnail_url.isEmpty()) { imageLoader.displayImage(info.uploader_thumbnail_url, uploaderThumb, displayImageOptions, new ImageErrorLoadingListener(activity, rootView, info.service_id)); @@ -418,7 +422,7 @@ public class VideoItemDetailFragment extends Fragment { } }); - if(info.audio_streams == null) { + if (info.audio_streams == null) { actionBarHandler.showAudioAction(false); } else { actionBarHandler.setOnPlayAudioListener(new ActionBarHandler.OnActionListener() { From 920c169d55a78131623872684f743ce2cf4c4bd5 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 20:22:01 +0200 Subject: [PATCH 13/14] update CI batch in README --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index f54fbccea..df4fcd5eb 100644 --- a/README.md +++ b/README.md @@ -9,7 +9,7 @@ NewPipe: A free lightweight Youtube frontend for Android. Project status: [![Translation Status](https://hosted.weblate.org/widgets/NewPipe/-/svg-badge.svg)](https://hosted.weblate.org/engage/NewPipe/) -[![Build Status](https://travis-ci.org/theScrabi/NewPipe.svg)](https://travis-ci.org/theScrabi/NewPipe) +[![Build Status](https://travis-ci.org/TeamNewPipe/NewPipe.svg)](https://travis-ci.org/TeamNewPipe/NewPipe) ## Donate ![Bitcoin](https://bitcoin.org/img/icons/logotop.svg) From f9ac199c1fb9386ab4b79f86ee202d75a9a9d6a0 Mon Sep 17 00:00:00 2001 From: Christian Schabesberger Date: Tue, 27 Sep 2016 21:33:26 +0200 Subject: [PATCH 14/14] fixed .webm download locatiion issue --- app/src/main/AndroidManifest.xml | 2 +- .../java/org/schabi/newpipe/MainActivity.java | 4 ++-- .../newpipe/detail/ActionBarHandler.java | 2 +- ...MainActivity.java => DownloadActivity.java} | 17 ++++++++++++----- .../newpipe/download/DownloadDialog.java | 6 ++++-- .../newpipe/settings/NewPipeSettings.java | 8 -------- .../us/shandian/giga/get/DownloadManager.java | 2 +- .../shandian/giga/get/DownloadManagerImpl.java | 8 ++++++-- .../giga/service/DownloadManagerService.java | 8 ++++---- .../java/us/shandian/giga/util/Utility.java | 18 +----------------- 10 files changed, 32 insertions(+), 43 deletions(-) rename app/src/main/java/org/schabi/newpipe/download/{MainActivity.java => DownloadActivity.java} (91%) diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 8a2f38540..5bae70262 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -133,7 +133,7 @@ diff --git a/app/src/main/java/org/schabi/newpipe/MainActivity.java b/app/src/main/java/org/schabi/newpipe/MainActivity.java index e94d7591c..5d4729e90 100644 --- a/app/src/main/java/org/schabi/newpipe/MainActivity.java +++ b/app/src/main/java/org/schabi/newpipe/MainActivity.java @@ -16,7 +16,7 @@ import org.schabi.newpipe.settings.SettingsActivity; * Created by Christian Schabesberger on 02.08.16. * * Copyright (C) Christian Schabesberger 2016 - * MainActivity.java is part of NewPipe. + * DownloadActivity.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 @@ -73,7 +73,7 @@ public class MainActivity extends AppCompatActivity { return true; } case R.id.action_show_downloads: { - Intent intent = new Intent(this, org.schabi.newpipe.download.MainActivity.class); + Intent intent = new Intent(this, org.schabi.newpipe.download.DownloadActivity.class); startActivity(intent); return true; } diff --git a/app/src/main/java/org/schabi/newpipe/detail/ActionBarHandler.java b/app/src/main/java/org/schabi/newpipe/detail/ActionBarHandler.java index feed040d1..57aaf9c5b 100644 --- a/app/src/main/java/org/schabi/newpipe/detail/ActionBarHandler.java +++ b/app/src/main/java/org/schabi/newpipe/detail/ActionBarHandler.java @@ -183,7 +183,7 @@ class ActionBarHandler { return true; case R.id.menu_item_downloads: { Intent intent = - new Intent(activity, org.schabi.newpipe.download.MainActivity.class); + new Intent(activity, org.schabi.newpipe.download.DownloadActivity.class); activity.startActivity(intent); return true; } diff --git a/app/src/main/java/org/schabi/newpipe/download/MainActivity.java b/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java similarity index 91% rename from app/src/main/java/org/schabi/newpipe/download/MainActivity.java rename to app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java index 60b64b1bf..a7e52c486 100644 --- a/app/src/main/java/org/schabi/newpipe/download/MainActivity.java +++ b/app/src/main/java/org/schabi/newpipe/download/DownloadActivity.java @@ -23,6 +23,7 @@ import android.view.View; import android.view.ViewTreeObserver; import android.widget.AdapterView; import android.widget.EditText; +import android.widget.RadioButton; import android.widget.SeekBar; import android.widget.TextView; import android.widget.Toast; @@ -41,13 +42,13 @@ import us.shandian.giga.ui.fragment.MissionsFragment; import us.shandian.giga.util.CrashHandler; import us.shandian.giga.util.Utility; -public class MainActivity extends AppCompatActivity implements AdapterView.OnItemClickListener{ +public class DownloadActivity extends AppCompatActivity implements AdapterView.OnItemClickListener{ public static final String INTENT_DOWNLOAD = "us.shandian.giga.intent.DOWNLOAD"; public static final String INTENT_LIST = "us.shandian.giga.intent.LIST"; - private static final String TAG = MainActivity.class.toString(); + private static final String TAG = DownloadActivity.class.toString(); public static final String THREADS = "threads"; @@ -150,6 +151,8 @@ public class MainActivity extends AppCompatActivity implements AdapterView.OnIte final TextView tCount = Utility.findViewById(v, R.id.threads_count); final SeekBar threads = Utility.findViewById(v, R.id.threads); final Toolbar toolbar = Utility.findViewById(v, R.id.toolbar); + final RadioButton audioButton = (RadioButton) Utility.findViewById(v, R.id.audio_button); + threads.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @@ -204,12 +207,16 @@ public class MainActivity extends AppCompatActivity implements AdapterView.OnIte File f = new File(mManager.getLocation() + "/" + fName); if (f.exists()) { - Toast.makeText(MainActivity.this, R.string.msg_exists, Toast.LENGTH_SHORT).show(); + Toast.makeText(DownloadActivity.this, R.string.msg_exists, Toast.LENGTH_SHORT).show(); } else { while (mBinder == null); - int res = mManager.startMission(getIntent().getData().toString(), fName, threads.getProgress() + 1); + int res = mManager.startMission( + getIntent().getData().toString(), + fName, + audioButton.isChecked(), + threads.getProgress() + 1); mBinder.onMissionAdded(mManager.getMission(res)); mFragment.notifyChange(); @@ -258,7 +265,7 @@ public class MainActivity extends AppCompatActivity implements AdapterView.OnIte return true; } case R.id.action_report_error: { - ErrorActivity.reportError(MainActivity.this, new Vector(), + ErrorActivity.reportError(DownloadActivity.this, new Vector(), null, null, ErrorActivity.ErrorInfo.make(ErrorActivity.USER_REPORT, null, diff --git a/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java b/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java index 57dd4bd85..5669a3308 100644 --- a/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java +++ b/app/src/main/java/org/schabi/newpipe/download/DownloadDialog.java @@ -225,6 +225,7 @@ public class DownloadDialog extends DialogFragment { int res = mManager.startMission( arguments.getString(AUDIO_URL), fName + arguments.getString(FILE_SUFFIX_AUDIO), + audioButton.isChecked(), threads.getProgress() + 1); mBinder.onMissionAdded(mManager.getMission(res)); } @@ -233,6 +234,7 @@ public class DownloadDialog extends DialogFragment { int res = mManager.startMission( arguments.getString(VIDEO_URL), fName + arguments.getString(FILE_SUFFIX_VIDEO), + audioButton.isChecked(), threads.getProgress() + 1); mBinder.onMissionAdded(mManager.getMission(res)); } @@ -255,8 +257,8 @@ public class DownloadDialog extends DialogFragment { //we'll see later FileDownloader.downloadFile(getContext(), url, saveFilePath, title); } else { - Intent intent = new Intent(getContext(), MainActivity.class); - intent.setAction(MainActivity.INTENT_DOWNLOAD); + Intent intent = new Intent(getContext(), DownloadActivity.class); + intent.setAction(DownloadActivity.INTENT_DOWNLOAD); intent.setData(Uri.parse(url)); intent.putExtra("fileName", createFileName(title) + fileSuffix); startActivity(intent); diff --git a/app/src/main/java/org/schabi/newpipe/settings/NewPipeSettings.java b/app/src/main/java/org/schabi/newpipe/settings/NewPipeSettings.java index 3934655b6..e4d6b6ea6 100644 --- a/app/src/main/java/org/schabi/newpipe/settings/NewPipeSettings.java +++ b/app/src/main/java/org/schabi/newpipe/settings/NewPipeSettings.java @@ -89,14 +89,6 @@ public class NewPipeSettings { return downloadPath; } - public static String getDownloadPath(Context context, String fileName) - { - if(Utility.isVideoFile(fileName)) { - return NewPipeSettings.getVideoDownloadPath(context); - } - return NewPipeSettings.getAudioDownloadPath(context); - } - private static File getFolder(Context context, int keyID, String defaultDirectoryName) { SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); final String key = context.getString(keyID); diff --git a/app/src/main/java/us/shandian/giga/get/DownloadManager.java b/app/src/main/java/us/shandian/giga/get/DownloadManager.java index 6090e1908..44eb0bb8e 100644 --- a/app/src/main/java/us/shandian/giga/get/DownloadManager.java +++ b/app/src/main/java/us/shandian/giga/get/DownloadManager.java @@ -4,7 +4,7 @@ public interface DownloadManager { int BLOCK_SIZE = 512 * 1024; - int startMission(String url, String name, int threads); + int startMission(String url, String name, boolean isAudio, int threads); void resumeMission(int id); void pauseMission(int id); void deleteMission(int id); diff --git a/app/src/main/java/us/shandian/giga/get/DownloadManagerImpl.java b/app/src/main/java/us/shandian/giga/get/DownloadManagerImpl.java index 558602ca3..498b9a079 100755 --- a/app/src/main/java/us/shandian/giga/get/DownloadManagerImpl.java +++ b/app/src/main/java/us/shandian/giga/get/DownloadManagerImpl.java @@ -31,11 +31,15 @@ public class DownloadManagerImpl implements DownloadManager } @Override - public int startMission(String url, String name, int threads) { + public int startMission(String url, String name, boolean isAudio, int threads) { DownloadMission mission = new DownloadMission(); mission.url = url; mission.name = name; - mission.location = NewPipeSettings.getDownloadPath(mContext, name); + if(isAudio) { + mission.location = NewPipeSettings.getAudioDownloadPath(mContext); + } else { + mission.location = NewPipeSettings.getVideoDownloadPath(mContext); + } mission.timestamp = System.currentTimeMillis(); mission.threadCount = threads; new Initializer(mContext, mission).start(); diff --git a/app/src/main/java/us/shandian/giga/service/DownloadManagerService.java b/app/src/main/java/us/shandian/giga/service/DownloadManagerService.java index ca85ae727..930075e0b 100755 --- a/app/src/main/java/us/shandian/giga/service/DownloadManagerService.java +++ b/app/src/main/java/us/shandian/giga/service/DownloadManagerService.java @@ -14,12 +14,12 @@ import android.os.Message; import android.support.v4.app.NotificationCompat.Builder; import android.util.Log; +import org.schabi.newpipe.download.DownloadActivity; import org.schabi.newpipe.settings.NewPipeSettings; import org.schabi.newpipe.R; import us.shandian.giga.get.DownloadManager; import us.shandian.giga.get.DownloadManagerImpl; import us.shandian.giga.get.DownloadMission; -import org.schabi.newpipe.download.MainActivity; import static org.schabi.newpipe.BuildConfig.DEBUG; public class DownloadManagerService extends Service implements DownloadMission.MissionListener @@ -53,7 +53,7 @@ public class DownloadManagerService extends Service implements DownloadMission.M Intent i = new Intent(); i.setAction(Intent.ACTION_MAIN); - i.setClass(this, MainActivity.class); + i.setClass(this, DownloadActivity.class); Drawable icon = this.getResources().getDrawable(R.mipmap.ic_launcher); @@ -68,8 +68,8 @@ public class DownloadManagerService extends Service implements DownloadMission.M PendingIntent.getActivity( this, 0, - new Intent(this, MainActivity.class) - .setAction(MainActivity.INTENT_LIST), + new Intent(this, DownloadActivity.class) + .setAction(DownloadActivity.INTENT_LIST), PendingIntent.FLAG_UPDATE_CURRENT ); diff --git a/app/src/main/java/us/shandian/giga/util/Utility.java b/app/src/main/java/us/shandian/giga/util/Utility.java index d38958b4b..856b841fe 100644 --- a/app/src/main/java/us/shandian/giga/util/Utility.java +++ b/app/src/main/java/us/shandian/giga/util/Utility.java @@ -27,13 +27,8 @@ public class Utility { public static enum FileType { - APP, VIDEO, - EXCEL, - WORD, - POWERPOINT, MUSIC, - ARCHIVE, UNKNOWN } @@ -142,22 +137,11 @@ public class Utility } public static FileType getFileType(String file) { - if (file.endsWith(".apk")) { - return FileType.APP; - } else if (file.endsWith(".mp3") || file.endsWith(".wav") || file.endsWith(".flac") || file.endsWith(".m4a")) { + if (file.endsWith(".mp3") || file.endsWith(".wav") || file.endsWith(".flac") || file.endsWith(".m4a")) { return FileType.MUSIC; } else if (file.endsWith(".mp4") || file.endsWith(".mpeg") || file.endsWith(".rm") || file.endsWith(".rmvb") || file.endsWith(".flv") || file.endsWith(".webp") || file.endsWith(".webm")) { return FileType.VIDEO; - } else if (file.endsWith(".doc") || file.endsWith(".docx")) { - return FileType.WORD; - } else if (file.endsWith(".xls") || file.endsWith(".xlsx")) { - return FileType.EXCEL; - } else if (file.endsWith(".ppt") || file.endsWith(".pptx")) { - return FileType.POWERPOINT; - } else if (file.endsWith(".zip") || file.endsWith(".rar") || file.endsWith(".7z") || file.endsWith(".gz") - || file.endsWith("tar") || file.endsWith(".bz")) { - return FileType.ARCHIVE; } else { return FileType.UNKNOWN; }