java获取flv视频直播流地址的起始图片

1. 获取图片前,首先我们需要引入相关maven依赖

<dependency>
            <groupId>org.bytedeco</groupId>
            <artifactId>ffmpeg</artifactId>
            <version>6.0-1.5.9</version>
        </dependency>
        <dependency>
            <groupId>org.bytedeco</groupId>
            <artifactId>javacv-platform</artifactId>
            <version>1.5.9</version>
        </dependency>

如依赖无法正常引入时,可通过百度寻找该jar并加入本地仓库中(jar引入方式见:本地Maven仓库导入外部jar

2. 创建java工具类ExtractFlvFirstFrame.java获取图片

import lombok.extern.slf4j.Slf4j;
import org.bytedeco.javacv.FFmpegFrameGrabber;
import org.bytedeco.javacv.Frame;
import org.bytedeco.javacv.FrameGrabber;
import org.bytedeco.javacv.Java2DFrameConverter;

import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;

@Slf4j
public class ExtractFlvFirstFrame {

    /**
     * 获取指定帧数的封面图片
     *
     * @param filePath flv地址(eg:http://ip:port/xxx.flv)
     */
    private static BufferedImage getBufferedImageByFrame(String filePath) throws IOException {
        FFmpegFrameGrabber grabber = FFmpegFrameGrabber.createDefault(filePath);
        return getBufferedImageByFrame(grabber);
    }

    private static BufferedImage getBufferedImageByFrame(FFmpegFrameGrabber grabber) throws FrameGrabber.Exception {
        grabber.start();
        Frame frame;
        frame = grabber.grabImage();
        Java2DFrameConverter converter = new Java2DFrameConverter();
        BufferedImage buffer = converter.getBufferedImage(frame);
        grabber.stop();
        return buffer;
    }

    /**
     * @param flvPath
     * @param imgPath 文件存储全路径
     * @throws Exception
     */
    public static File getFlvImg(String flvPath, String imgPath) {
        try {
            bufferedImageToByteArray(getBufferedImageByFrame(flvPath), imgPath);
            return new File(imgPath);
        } catch (IOException e) {
            e.printStackTrace();
            log.error("通过视频流地址“" + flvPath + "”生成图片“" + imgPath + "”失败");
        }
        return null;
    }

    /**
     * 将BufferedImage转换为byte[]
     *
     * @param image
     * @param imgPath 文件存储全路径
     * @return
     */
    private static void bufferedImageToByteArray(BufferedImage image, String imgPath) throws IOException {
        ImageIO.write(image, "jpg", new File(imgPath));
    }

}

调用方法getFlvImg即可获得直播视频流的其实帧图,其实入参flvPath为直播的flv地址全路径,imgPath为要保存的图片的全路径(含拓展名,eg: C:/aaa/123.jpg)

注意:
jar版本请勿随意使用,另外需要注意的是该方式虽然能获取首帧的图片,但是项目打包后会非常的大。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要使用ExoPlayer播放FLV格式的直播,你需要进行一些额外的配置。以下是一个示例代码: 首先,在你的Android项目的 build.gradle 文件中添加以下依赖项: ```groovy implementation 'com.google.android.exoplayer:exoplayer-core:2.15.1' implementation 'com.google.android.exoplayer:exoplayer-ui:2.15.1' implementation 'com.google.android.exoplayer:extension-rtmp:2.15.1' implementation 'com.google.android.exoplayer:extension-ffmpeg:2.15.1' ``` 接下来,在你的Activity或Fragment中使用以下代码来播放FLV格式的直播: ```java import android.net.Uri; import android.os.Bundle; import androidx.appcompat.app.AppCompatActivity; import com.google.android.exoplayer2.ExoPlayer; import com.google.android.exoplayer2.SimpleExoPlayer; import com.google.android.exoplayer2.source.MediaSource; import com.google.android.exoplayer2.source.ProgressiveMediaSource; import com.google.android.exoplayer2.ui.PlayerView; import com.google.android.exoplayer2.upstream.DefaultDataSourceFactory; import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory; import com.google.android.exoplayer2.upstream.DefaultHttpDataSource; public class MainActivity extends AppCompatActivity { private static final String RTMP_URL = "your_rtmp_url_here"; private SimpleExoPlayer player; private PlayerView playerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); playerView = findViewById(R.id.player_view); // 创建ExoPlayer实例 player = new SimpleExoPlayer.Builder(this).build(); // 设置播放器视图 playerView.setPlayer(player); // 创建媒体资源 MediaSource mediaSource = buildMediaSource(Uri.parse(RTMP_URL)); // 准备播放 player.prepare(mediaSource); // 开始播放 player.setPlayWhenReady(true); } private MediaSource buildMediaSource(Uri uri) { DefaultDataSourceFactory dataSourceFactory = new DefaultDataSourceFactory(this, "exoplayer"); // 使用DefaultHttpDataSourceFactory来处理RTMP DefaultHttpDataSource.Factory httpDataSourceFactory = new DefaultHttpDataSource.Factory() .setAllowCrossProtocolRedirects(true) .setUserAgent("exoplayer"); dataSourceFactory.setHttpDataSourceFactory(httpDataSourceFactory); // 创建ProgressiveMediaSource.Builder来构建媒体资源 ProgressiveMediaSource.Factory mediaSourceFactory = new ProgressiveMediaSource.Factory(dataSourceFactory); // 设置扩展选项以支持FLV格式 mediaSourceFactory.setCustomCacheKey(RTMP_URL); mediaSourceFactory.setLoadErrorHandlingPolicy(new ExoPlayerLoadErrorHandlingPolicy()); // 创建媒体资源 return mediaSourceFactory.createMediaSource(uri); } @Override protected void onDestroy() { super.onDestroy(); // 释放资源 player.release(); } } ``` 请将 `your_rtmp_url_here` 替换为你要播放的RTMP地址。 在这个示例中,我们创建了一个ExoPlayer实例,并将其与一个PlayerView关联起来。然后,我们构建了一个媒体资源,并通过使用 `ProgressiveMediaSource.Builder` 来设置扩展选项以支持FLV格式。最后,我们准备播放并开始播放。 为了支持处理RTMP,我们使用了 `DefaultHttpDataSource.Factory` 来处理HTTP请求。这里设置了一些选项,如允许跨域重定向和自定义用户代理。 为了处理加载错误,我们创建了一个自定义的 `ExoPlayerLoadErrorHandlingPolicy` 类,你需要根据你的需求进行相应的实现。 请注意,这只是一个简单的示例代码,你可以根据你的具体需求进行相应的修改和扩展。 希望这个示例能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值