Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
io.github.jdpxiaoming:ijkplayer-armv7a
Advanced tools
ijkplayer open the rtsp & h265 surpport .
implementation 'io.github.jdpxiaoming:ijkplayer-view:0.0.26'
implementation 'io.github.jdpxiaoming:ijkplayer-java:0.0.26'
implementation 'io.github.jdpxiaoming:ijkplayer-armv7a:0.0.26'
//看情况如果需要64位so则引入.
implementation 'io.github.jdpxiaoming:ijkplayer-arm64:0.0.26'
// init player
IjkMediaPlayer.loadLibrariesOnce(null);
IjkMediaPlayer.native_profileBegin(IjkMediaPlayer.IJK_LIB_NAME_FFMPEG);
//打开opense,h264下有效.
mVideoView.setAudioHardWare(true);
mVideoView.setVideoPath(mVideoPath, IjkVideoView.IJK_TYPE_CUSTOMER_PLAY)
//设置视频旋转角度.
mVideoView?.isIgnoreRotation = false;
mVideoView?.setVideoRotationDegree(0)
AV_SYNC_VIDEO_MASTER
,默认为音频同步为主. //准备就绪,做一些配置操作,比如音视频同步方式.
mVideoView.setOnPreparedListener(new IMediaPlayer.OnPreparedListener() {
@Override
public void onPrepared(IMediaPlayer mp) {
Log.e(TAG, "onPrepared#done! ");
mVideoView.openZeroVideoDelay(true);
}
});
//打开视频0延迟.
mVideoView.openZeroVideoDelay(true);
mVideoView.setAspectRatio(IRenderView.AR_16_9_FIT_PARENT);
//超时单位微妙.2s = 2*1000*1000
mVideoView.setTimeout(2*1000*1000);
surrfaceView
默认:TexutureView
mVideoView.setRender(IjkVideoView.RENDER_SURFACE_VIEW);
//拉伸满屏.
mIjkVideoView.setAspectRatio(IRenderView.AR_MATCH_PARENT);
public interface IRenderView {
int AR_ASPECT_FIT_PARENT = 0;
int AR_ASPECT_FILL_PARENT = 1;
int AR_ASPECT_WRAP_CONTENT = 2;
int AR_MATCH_PARENT = 3;
int AR_16_9_FIT_PARENT = 4;
int AR_4_3_FIT_PARENT = 5;
...
}
public static final int IJK_TYPE_LIVING_WATCH = 1; //实时监控,要求首开速度,延迟略高一点
public static final int IJK_TYPE_LIVING_LOW_DELAY = 2; //实时直播要求低延迟,不要求首开熟读 .
public static final int IJK_TYPE_HTTP_PLAY = 3;//录播 mp4 /hls/flv...
public static final int IJK_TYPE_FILE_PLAY = 10;//本地文件播放 .
public static final int IJK_TYPE_CUSTOMER_PLAY = 20;//用户自定义参数模式,需要先调用方法设置参数(setCustomerValue),否则使用ijk默认参数
public static final int IJK_TYPE_PLAY_DEFAULT = IJK_TYPE_LIVING_WATCH;//默认播放类型.
mVideoView.setVideoPath(mVideoPath, IjkVideoView.IJK_TYPE_HTTP_PLAY);
header
-user-agent
//set the headers properties in user-agent.
mVideoView.setUserAgentStr("Android_Station_V1.1.1");
implementation 'com.danikula:videocache:2.7.1'
/**
* comment:
* author : poe.Cai
* date : 2020/5/28 10:31
*/
public class PApplication extends Application {
private HttpProxyCacheServer proxy;
public static HttpProxyCacheServer getProxy(Context context) {
PApplication app = (PApplication) context.getApplicationContext();
return app.proxy == null ? (app.proxy = app.newProxy()) : app.proxy;
}
private HttpProxyCacheServer newProxy() {
// return new HttpProxyCacheServer(this);
return new HttpProxyCacheServer.Builder(this)
.maxCacheSize(10 * 1024 * 1024) // 1 Gb for cache,oss的视频3分钟一般在10M以下.
.build();
}
}
mVideoPath = "https://ovopark-record.oss-cn-shanghai.aliyuncs.com/039570f6-e4c3-4a1b-9886-5ad7e6d7181f.mp4";
HttpProxyCacheServer proxy = PApplication.getProxy(this);
String proxyUrl = proxy.getProxyUrl(mVideoPath);
mVideoView.setVideoPath(proxyUrl, IjkVideoView.IJK_TYPE_HTTP_PLAY);
打开了rtsp的开关
#rtsp支持.
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-demuxer=rtsp"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-demuxer=mjpeg"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-demuxer=sdp"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-demuxer=rtp"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-decoder=mjpeg"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-protocol=rtp"
export COMMON_FF_CFG_FLAGS="$COMMON_FF_CFG_FLAGS --enable-protocol=tcp"
直接运行ijkplayer-example即可。
所以你的targetAPI <= 25 最好,如果有高版本需求请自行编译.
配置1. 速度首开50
IJKMEDIA: ===== options =====
IJKMEDIA: player-opts : opensles = 1
IJKMEDIA: player-opts : overlay-format = 842225234
IJKMEDIA: player-opts : mediacodec = 1
IJKMEDIA: player-opts : mediacodec-hevc = 1
IJKMEDIA: player-opts : packet-buffering = 0
IJKMEDIA: player-opts : fast = 1
IJKMEDIA: player-opts : mediacodec-handle-resolution-change = 0
IJKMEDIA: player-opts : framedrop = 1
IJKMEDIA: player-opts : start-on-prepared = 1
IJKMEDIA: player-opts : reconnect = 5
IJKMEDIA: format-opts : ijkapplication = -1284518032
IJKMEDIA: format-opts : ijkiomanager = -1414032000
IJKMEDIA: format-opts : rtsp_transport = tcp
IJKMEDIA: format-opts : rtsp_flags = prefer_tcp
IJKMEDIA: format-opts : http-detect-range-support = 1
IJKMEDIA: format-opts : buffer_size = 1316
IJKMEDIA: format-opts : max-buffer-size = 0
IJKMEDIA: format-opts : infbuf = 1
IJKMEDIA: format-opts : analyzemaxduration = 100
IJKMEDIA: format-opts : probesize = 1024
IJKMEDIA: format-opts : flush_packets = 1
IJKMEDIA: codec-opts : skip_loop_filter = 48
IJKMEDIA: ===================
配置2. 首开速度20左右
===== options =====
SDL_RunThread: [30113] ff_msg_loop
player-opts : opensles = 1
player-opts : overlay-format = 842225234
message_loop
player-opts : mediacodec = 1
player-opts : mediacodec-hevc = 1
player-opts : packet-buffering = 0
player-opts : fast = 1
player-opts : mediacodec-handle-resolution-change = 0
player-opts : framedrop = 1
player-opts : start-on-prepared = 1
player-opts : reconnect = 5
format-opts : ijkapplication = -1351159456
format-opts : ijkiomanager = -1078774656
format-opts : rtsp_transport = tcp
format-opts : rtsp_flags = prefer_tcp
format-opts : http-detect-range-support = 1
format-opts : buffer_size = 1024
format-opts : max-buffer-size = 0
format-opts : max-fps = 20
format-opts : infbuf = 1
format-opts : analyzemaxduration = 80
format-opts : probesize = 800
format-opts : flush_packets = 1
codec-opts : skip_loop_filter = 48
===================
FAQs
Video player based on FFmpeg n4.0
We found that io.github.jdpxiaoming:ijkplayer-armv7a demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.