Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_26386469
GSYVideoPlayer
提交
41e4a71b
G
GSYVideoPlayer
项目概览
qq_26386469
/
GSYVideoPlayer
与 Fork 源项目一致
从无法访问的项目Fork
通知
5
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
GSYVideoPlayer
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
41e4a71b
编写于
7月 22, 2019
作者:
G
guoshuyu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#2142
上级
ee3c8a1a
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
263 addition
and
1 deletion
+263
-1
app/src/main/AndroidManifest.xml
app/src/main/AndroidManifest.xml
+6
-0
app/src/main/java/com/example/gsyvideoplayer/DetailNormalActivityPlayer.java
...om/example/gsyvideoplayer/DetailNormalActivityPlayer.java
+228
-0
app/src/main/java/com/example/gsyvideoplayer/MainActivity.java
...rc/main/java/com/example/gsyvideoplayer/MainActivity.java
+4
-1
app/src/main/java/com/example/gsyvideoplayer/utils/JumpUtils.java
...main/java/com/example/gsyvideoplayer/utils/JumpUtils.java
+11
-0
app/src/main/res/layout/activity_main.xml
app/src/main/res/layout/activity_main.xml
+6
-0
gsyVideoPlayer-java/src/main/java/com/shuyu/gsyvideoplayer/utils/CommonUtil.java
.../main/java/com/shuyu/gsyvideoplayer/utils/CommonUtil.java
+8
-0
未找到文件。
app/src/main/AndroidManifest.xml
浏览文件 @
41e4a71b
...
...
@@ -202,6 +202,12 @@
android:theme=
"@style/Theme.AppCompat.Transitions"
android:screenOrientation=
"portrait"
/>
<activity
android:name=
".DetailNormalActivityPlayer"
android:configChanges=
"orientation|keyboardHidden|screenSize"
android:theme=
"@style/Theme.AppCompat.Transitions"
android:screenOrientation=
"portrait"
/>
<meta-data
android:name=
"android.max_aspect"
android:value=
"2.1"
/>
...
...
app/src/main/java/com/example/gsyvideoplayer/DetailNormalActivityPlayer.java
0 → 100644
浏览文件 @
41e4a71b
package
com.example.gsyvideoplayer
;
import
android.app.Activity
;
import
android.content.res.Configuration
;
import
android.os.Bundle
;
import
android.view.View
;
import
android.widget.ImageView
;
import
android.widget.RelativeLayout
;
import
androidx.appcompat.app.AppCompatActivity
;
import
androidx.core.widget.NestedScrollView
;
import
com.example.gsyvideoplayer.video.LandLayoutVideo
;
import
com.google.android.exoplayer2.SeekParameters
;
import
com.shuyu.gsyvideoplayer.GSYVideoManager
;
import
com.shuyu.gsyvideoplayer.builder.GSYVideoOptionBuilder
;
import
com.shuyu.gsyvideoplayer.listener.GSYSampleCallBack
;
import
com.shuyu.gsyvideoplayer.listener.GSYVideoProgressListener
;
import
com.shuyu.gsyvideoplayer.listener.LockClickListener
;
import
com.shuyu.gsyvideoplayer.utils.Debuger
;
import
com.shuyu.gsyvideoplayer.utils.OrientationUtils
;
import
com.shuyu.gsyvideoplayer.video.base.GSYVideoPlayer
;
import
java.util.HashMap
;
import
java.util.Map
;
import
butterknife.BindView
;
import
butterknife.ButterKnife
;
import
tv.danmaku.ijk.media.exo2.Exo2PlayerManager
;
public
class
DetailNormalActivityPlayer
extends
Activity
{
@BindView
(
R
.
id
.
post_detail_nested_scroll
)
NestedScrollView
postDetailNestedScroll
;
//推荐使用StandardGSYVideoPlayer,功能一致
//CustomGSYVideoPlayer部分功能处于试验阶段
@BindView
(
R
.
id
.
detail_player
)
LandLayoutVideo
detailPlayer
;
@BindView
(
R
.
id
.
activity_detail_player
)
RelativeLayout
activityDetailPlayer
;
private
boolean
isPlay
;
private
boolean
isPause
;
private
OrientationUtils
orientationUtils
;
@Override
protected
void
onCreate
(
Bundle
savedInstanceState
)
{
super
.
onCreate
(
savedInstanceState
);
setContentView
(
R
.
layout
.
activity_detail_player
);
ButterKnife
.
bind
(
this
);
String
url
=
getUrl
();
//增加封面
ImageView
imageView
=
new
ImageView
(
this
);
imageView
.
setScaleType
(
ImageView
.
ScaleType
.
CENTER_CROP
);
imageView
.
setImageResource
(
R
.
mipmap
.
xxx1
);
resolveNormalVideoUI
();
//外部辅助的旋转,帮助全屏
orientationUtils
=
new
OrientationUtils
(
this
,
detailPlayer
);
//初始化不打开外部的旋转
orientationUtils
.
setEnable
(
false
);
Map
<
String
,
String
>
header
=
new
HashMap
<>();
header
.
put
(
"ee"
,
"33"
);
header
.
put
(
"allowCrossProtocolRedirects"
,
"true"
);
GSYVideoOptionBuilder
gsyVideoOption
=
new
GSYVideoOptionBuilder
();
gsyVideoOption
.
setThumbImageView
(
imageView
)
.
setIsTouchWiget
(
true
)
.
setRotateViewAuto
(
false
)
.
setLockLand
(
false
)
.
setAutoFullWithSize
(
false
)
.
setShowFullAnimation
(
false
)
.
setNeedLockFull
(
true
)
.
setUrl
(
url
)
.
setMapHeadData
(
header
)
.
setCacheWithPlay
(
false
)
.
setVideoTitle
(
"测试视频"
)
.
setVideoAllCallBack
(
new
GSYSampleCallBack
()
{
@Override
public
void
onPrepared
(
String
url
,
Object
...
objects
)
{
Debuger
.
printfError
(
"***** onPrepared **** "
+
objects
[
0
]);
Debuger
.
printfError
(
"***** onPrepared **** "
+
objects
[
1
]);
super
.
onPrepared
(
url
,
objects
);
//开始播放了才能旋转和全屏
orientationUtils
.
setEnable
(
true
);
isPlay
=
true
;
//设置 seek 的临近帧。
if
(
detailPlayer
.
getGSYVideoManager
().
getPlayer
()
instanceof
Exo2PlayerManager
)
{
((
Exo2PlayerManager
)
detailPlayer
.
getGSYVideoManager
().
getPlayer
()).
setSeekParameter
(
SeekParameters
.
NEXT_SYNC
);
Debuger
.
printfError
(
"***** setSeekParameter **** "
);
}
}
@Override
public
void
onEnterFullscreen
(
String
url
,
Object
...
objects
)
{
super
.
onEnterFullscreen
(
url
,
objects
);
Debuger
.
printfError
(
"***** onEnterFullscreen **** "
+
objects
[
0
]);
//title
Debuger
.
printfError
(
"***** onEnterFullscreen **** "
+
objects
[
1
]);
//当前全屏player
}
@Override
public
void
onAutoComplete
(
String
url
,
Object
...
objects
)
{
super
.
onAutoComplete
(
url
,
objects
);
}
@Override
public
void
onClickStartError
(
String
url
,
Object
...
objects
)
{
super
.
onClickStartError
(
url
,
objects
);
}
@Override
public
void
onQuitFullscreen
(
String
url
,
Object
...
objects
)
{
super
.
onQuitFullscreen
(
url
,
objects
);
Debuger
.
printfError
(
"***** onQuitFullscreen **** "
+
objects
[
0
]);
//title
Debuger
.
printfError
(
"***** onQuitFullscreen **** "
+
objects
[
1
]);
//当前非全屏player
if
(
orientationUtils
!=
null
)
{
orientationUtils
.
backToProtVideo
();
}
}
})
.
setLockClickListener
(
new
LockClickListener
()
{
@Override
public
void
onClick
(
View
view
,
boolean
lock
)
{
if
(
orientationUtils
!=
null
)
{
//配合下方的onConfigurationChanged
orientationUtils
.
setEnable
(!
lock
);
}
}
})
.
setGSYVideoProgressListener
(
new
GSYVideoProgressListener
()
{
@Override
public
void
onProgress
(
int
progress
,
int
secProgress
,
int
currentPosition
,
int
duration
)
{
Debuger
.
printfLog
(
" progress "
+
progress
+
" secProgress "
+
secProgress
+
" currentPosition "
+
currentPosition
+
" duration "
+
duration
);
}
})
.
build
(
detailPlayer
);
detailPlayer
.
getFullscreenButton
().
setOnClickListener
(
new
View
.
OnClickListener
()
{
@Override
public
void
onClick
(
View
v
)
{
//直接横屏
orientationUtils
.
resolveByClick
();
//第一个true是否需要隐藏actionbar,第二个true是否需要隐藏statusbar
detailPlayer
.
startWindowFullscreen
(
DetailNormalActivityPlayer
.
this
,
false
,
true
);
}
});
}
@Override
public
void
onBackPressed
()
{
if
(
orientationUtils
!=
null
)
{
orientationUtils
.
backToProtVideo
();
}
if
(
GSYVideoManager
.
backFromWindowFull
(
this
))
{
return
;
}
super
.
onBackPressed
();
}
@Override
protected
void
onPause
()
{
getCurPlay
().
onVideoPause
();
super
.
onPause
();
isPause
=
true
;
}
@Override
protected
void
onResume
()
{
getCurPlay
().
onVideoResume
(
false
);
super
.
onResume
();
isPause
=
false
;
}
@Override
protected
void
onDestroy
()
{
super
.
onDestroy
();
if
(
isPlay
)
{
getCurPlay
().
release
();
}
//GSYPreViewManager.instance().releaseMediaPlayer();
if
(
orientationUtils
!=
null
)
orientationUtils
.
releaseListener
();
}
@Override
public
void
onConfigurationChanged
(
Configuration
newConfig
)
{
super
.
onConfigurationChanged
(
newConfig
);
//如果旋转了就全屏
if
(
isPlay
&&
!
isPause
)
{
detailPlayer
.
onConfigurationChanged
(
this
,
newConfig
,
orientationUtils
,
true
,
true
);
}
}
private
void
resolveNormalVideoUI
()
{
//增加title
detailPlayer
.
getTitleTextView
().
setVisibility
(
View
.
GONE
);
detailPlayer
.
getBackButton
().
setVisibility
(
View
.
GONE
);
}
private
GSYVideoPlayer
getCurPlay
()
{
if
(
detailPlayer
.
getFullWindowPlayer
()
!=
null
)
{
return
detailPlayer
.
getFullWindowPlayer
();
}
return
detailPlayer
;
}
private
String
getUrl
()
{
return
"http://9890.vod.myqcloud.com/9890_4e292f9a3dd011e6b4078980237cc3d3.f20.mp4"
;
}
}
app/src/main/java/com/example/gsyvideoplayer/MainActivity.java
浏览文件 @
41e4a71b
...
...
@@ -54,7 +54,7 @@ public class MainActivity extends AppCompatActivity {
@OnClick
({
R
.
id
.
open_btn
,
R
.
id
.
list_btn
,
R
.
id
.
list_btn_2
,
R
.
id
.
list_detail
,
R
.
id
.
clear_cache
,
R
.
id
.
recycler
,
R
.
id
.
recycler_2
,
R
.
id
.
list_detail_list
,
R
.
id
.
web_detail
,
R
.
id
.
danmaku_video
,
R
.
id
.
fragment_video
,
R
.
id
.
more_type
,
R
.
id
.
input_type
,
R
.
id
.
open_btn_empty
,
R
.
id
.
open_control
,
R
.
id
.
open_filter
,
R
.
id
.
open_btn_pick
,
R
.
id
.
open_btn_auto
,
R
.
id
.
open_scroll
,
R
.
id
.
open_window
,
R
.
id
.
open_btn_ad
,
R
.
id
.
open_btn_multi
,
R
.
id
.
open_btn_ad2
,
R
.
id
.
open_list_ad
,
R
.
id
.
open_custom_exo
,
R
.
id
.
open_simple
,
R
.
id
.
open_switch
,
R
.
id
.
media_codec
})
R
.
id
.
open_btn_multi
,
R
.
id
.
open_btn_ad2
,
R
.
id
.
open_list_ad
,
R
.
id
.
open_custom_exo
,
R
.
id
.
open_simple
,
R
.
id
.
open_switch
,
R
.
id
.
media_codec
,
R
.
id
.
detail_normal_activity
})
public
void
onClick
(
View
view
)
{
switch
(
view
.
getId
())
{
case
R
.
id
.
open_simple
:
...
...
@@ -159,6 +159,9 @@ public class MainActivity extends AppCompatActivity {
case
R
.
id
.
media_codec
:
JumpUtils
.
goMediaCodec
(
this
);
break
;
case
R
.
id
.
detail_normal_activity
:
JumpUtils
.
goToDetailNormalActivity
(
this
);
break
;
case
R
.
id
.
clear_cache
:
//清理缓存
GSYVideoManager
.
instance
().
clearAllDefaultCache
(
MainActivity
.
this
);
...
...
app/src/main/java/com/example/gsyvideoplayer/utils/JumpUtils.java
浏览文件 @
41e4a71b
...
...
@@ -15,6 +15,7 @@ import com.example.gsyvideoplayer.DetailControlActivity;
import
com.example.gsyvideoplayer.DetailFilterActivity
;
import
com.example.gsyvideoplayer.DetailListPlayer
;
import
com.example.gsyvideoplayer.DetailMoreTypeActivity
;
import
com.example.gsyvideoplayer.DetailNormalActivityPlayer
;
import
com.example.gsyvideoplayer.DetailPlayer
;
import
com.example.gsyvideoplayer.FragmentVideoActivity
;
import
com.example.gsyvideoplayer.InputUrlDetailActivity
;
...
...
@@ -244,6 +245,16 @@ public class JumpUtils {
activity
.
startActivity
(
intent
);
}
/**
* 跳转到详情播放
*
* @param activity
*/
public
static
void
goToDetailNormalActivity
(
Activity
activity
)
{
Intent
intent
=
new
Intent
(
activity
,
DetailNormalActivityPlayer
.
class
);
activity
.
startActivity
(
intent
);
}
/**
* 跳转到详情播放
*
...
...
app/src/main/res/layout/activity_main.xml
浏览文件 @
41e4a71b
...
...
@@ -204,6 +204,12 @@
android:text=
"硬解码支持"
/>
<Button
android:id=
"@+id/detail_normal_activity"
android:layout_width=
"240dp"
android:layout_height=
"wrap_content"
android:layout_marginTop=
"20dp"
android:text=
"普通 Activity"
/>
<Button
android:id=
"@+id/open_custom_exo"
android:layout_width=
"240dp"
...
...
gsyVideoPlayer-java/src/main/java/com/shuyu/gsyvideoplayer/utils/CommonUtil.java
浏览文件 @
41e4a71b
...
...
@@ -13,6 +13,7 @@ import androidx.appcompat.app.AppCompatActivity;
import
androidx.appcompat.view.ContextThemeWrapper
;
import
androidx.appcompat.widget.TintContextWrapper
;
import
androidx.fragment.app.FragmentActivity
;
import
android.util.DisplayMetrics
;
import
android.util.TypedValue
;
import
android.view.Surface
;
...
...
@@ -124,6 +125,10 @@ public class CommonUtil {
FragmentActivity
fragmentActivity
=
(
FragmentActivity
)
context
;
fragmentActivity
.
getWindow
().
setFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
,
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
}
else
if
(
context
instanceof
Activity
)
{
Activity
activity
=
(
Activity
)
context
;
activity
.
getWindow
().
setFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
,
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
}
else
{
CommonUtil
.
getAppCompActivity
(
context
).
getWindow
().
setFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
,
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
...
...
@@ -148,6 +153,9 @@ public class CommonUtil {
if
(
context
instanceof
FragmentActivity
)
{
FragmentActivity
fragmentActivity
=
(
FragmentActivity
)
context
;
fragmentActivity
.
getWindow
().
clearFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
}
else
if
(
context
instanceof
Activity
)
{
Activity
activity
=
(
Activity
)
context
;
activity
.
getWindow
().
clearFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
}
else
{
CommonUtil
.
getAppCompActivity
(
context
).
getWindow
().
clearFlags
(
WindowManager
.
LayoutParams
.
FLAG_FULLSCREEN
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录