javaCV视频处理之提取人像视频
效果图对比
文章图片
左侧的为原视频,右侧为提取人像跳舞的视频。
pom文件引入依赖
com.baidu.aip java-sdk4.16.3 org.bytedeco javacv-platform1.5.5
java核心实现代码(完整)
import com.baidu.aip.bodyanalysis.AipBodyAnalysis; import org.bytedeco.javacv.FFmpegFrameGrabber; import org.bytedeco.javacv.FFmpegFrameRecorder; import org.bytedeco.javacv.Frame; import org.bytedeco.javacv.Java2DFrameConverter; import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.io.*; import java.util.HashMap; import org.bytedeco.ffmpeg.global.avutil; import org.bytedeco.ffmpeg.global.avcodec; import org.json.JSONObject; import sun.misc.BASE64Decoder; public class VideoProcessor {//设置APPID/AK/SKpublic static final String APP_ID = "25393592"; public static final String API_KEY = "OkRDD6FQwm5hTKGSMIEL9RN4"; public static final String SECRET_KEY = "ONAxohflnqL2HwBEQB2iGUCjmO5lgywp"; final static String videoFolderPath = "C:/Users/liuya/Desktop/video/"; final static String videoName = "demo.mp4"; final static String imageFolderPath = "C:/Users/liuya/Desktop/people/"; public static void main(String[] args) throws Exception {videoProcess(videoFolderPath + videoName); } //视频水印public static void videoProcess(String filePath) {//抓取视频图像资源FFmpegFrameGrabber videoGrabber = new FFmpegFrameGrabber(filePath); //抓取视频图像资源FFmpegFrameGrabber audioGrabber = new FFmpegFrameGrabber(filePath); try {videoGrabber.start(); audioGrabber.start(); FFmpegFrameRecorder recorder = new FFmpegFrameRecorder(videoFolderPath + "new" + videoName, videoGrabber.getImageWidth(), videoGrabber.getImageHeight(), videoGrabber.getAudioChannels()); recorder.setPixelFormat(avutil.AV_PIX_FMT_YUV420P); recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264); recorder.start(); //处理图像int videoSize = videoGrabber.getLengthInVideoFrames(); for (int i = 0; i < videoSize; i++) {Frame videoFrame = videoGrabber.grabImage(); if (videoFrame != null && videoFrame.image != null) {System.out.println("视频共" + videoSize + "帧,正处理第" + (i + 1) + "帧图片"); Java2DFrameConverter converter = new Java2DFrameConverter(); BufferedImage bi=converter.getBufferedImage(videoFrame); BufferedImage bufferedImage = splitting(bi); recorder.record(converter.convert(bufferedImage)); }}//处理音频for (int i = 0; i < audioGrabber.getLengthInAudioFrames(); i++) {Frame audioFrame = audioGrabber.grabSamples(); if (audioFrame != null && audioFrame.samples != null) {recorder.recordSamples(audioFrame.sampleRate, audioFrame.audioChannels, audioFrame.samples); }}recorder.stop(); recorder.release(); videoGrabber.stop(); audioGrabber.stop(); } catch (Exception e) {e.printStackTrace(); }} public static BufferedImage splitting(BufferedImage image){ByteArrayOutputStream out=new ByteArrayOutputStream(); try {ImageIO.write(image,"png",out); } catch (IOException e) {e.printStackTrace(); }return splitting(out.toByteArray()); } public static BufferedImage splitting(byte[] image){// 初始化一个AipBodyAnalysisAipBodyAnalysis client = new AipBodyAnalysis(APP_ID, API_KEY, SECRET_KEY); // 可选:设置网络连接参数client.setConnectionTimeoutInMillis(2000); client.setSocketTimeoutInMillis(60000); // 传入可选参数调用接口HashMap options = new HashMap(); options.put("type", "foreground"); // 参数为本地路径JSONObject res = client.bodySeg(image, options); returnconvert(res.get("foreground").toString()); } public static BufferedImage convert(String labelmapBase64) {try {BASE64Decoder decoder = new BASE64Decoder(); byte[] bytes = decoder.decodeBuffer(labelmapBase64); InputStream is = new ByteArrayInputStream(bytes); BufferedImage image = ImageIO.read(is); //失真处理BufferedImage newBufferedImage = new BufferedImage(image.getWidth(), image.getHeight(), BufferedImage.TYPE_INT_RGB); newBufferedImage.createGraphics().drawImage(image, 0, 0, Color.WHITE, null); ByteArrayOutputStream out=new ByteArrayOutputStream(); ImageIO.write(newBufferedImage, "png", out); ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray()); return ImageIO.read(in); } catch (IOException e) {e.printStackTrace(); return null; }} }
控制台输出

文章图片
【javaCV视频处理之提取人像视频】到此这篇关于javaCV视频处理之提取人像视频的文章就介绍到这了,更多相关javaCV提取人像视频内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- Java|Java OpenCV图像处理之SIFT角点检测详解
- 事件处理程序
- 4月23日海军节,我在青岛等你,一起看强大的中国海军。(如图如视频)
- 视频转换器哪种好用()
- 不懂法,害人终害己
- 腾讯视频(我有一段rap想给你说)
- 爬虫数据处理HTML转义字符
- 百度云极速下载,来体验飞的感觉,还可以看最新动漫的百度云视频哦
- Android|Android BLE蓝牙连接异常处理
- 视频搬运工小赵-10#16.04元