Xuggler屏幕影响声音记录的记录代码

如何解决Xuggler屏幕影响声音记录的记录代码

| 我正在开发用于带音频截屏的应用程序。屏幕上的声音录制工作正常,但问题是假设我录制了5分钟,然后生成的视频文件是5分钟,但是生成的音频文件是4分钟45秒。因此,基本上,问题在于音频和视频都不同步,与视频文件相比,音频文件的持续时间更短。 音频和视频文件录制都在单独的线程中运行,但是仍然有问题。 VideoCaptureing代码:
public void run() {
    setVideoParameters();

    FRAME_RATE = frameRate;
    // let\'s make a IMediaWriter to write the file.
    writer = ToolFactory.makeWriter(movieFile.getName());

    screenBounds = new Rectangle(RecorderSettings.m_CapRectX,RecorderSettings.m_CapRecY,(int) RecorderSettings.m_CapRectWidth,(int) RecorderSettings.m_CapRecHeight);

    // We tell it we\'re going to add one video stream,with id 0,// at position 0,and that it will have a fixed frame rate of
    // FRAME_RATE.

    // ScreenWidth && ScreenHeight multiplied by 3/4 to reduce pixel to 3/4
    // of actual.
    // writer.addVideoStream(0,ICodec.ID.CODEC_ID_MPEG4,// screenBounds.width,screenBounds.height );
    writer.addVideoStream(0,vcodec.getID(),(screenBounds.width * upperLimit) / lowerLimit,(screenBounds.height * upperLimit) / lowerLimit);

    // To have start time of recording
    startTime = System.nanoTime();


    while (isStopProceesBtnClk) {
        try {
            if (!isStopProceesBtnClk) {
                break;
            } else {
                synchronized (this) {
                    while (isPauseProceesBtnClk) {
                        try {
                            // catches starting time of pause.
                            pauseStartTime = System.nanoTime();
                            wait();
                        } catch (Exception e) {
                            e.printStackTrace();
                        }
                    }
                }


                BufferedImage screen = getDesktopScreenshot();
            // convert to the right image type
                  BufferedImage bgrScreen = convertToType(screen,BufferedImage.TYPE_3BYTE_BGR);


                // encode the image to stream #0
                if (totalPauseTime > 0) {
                    writer.encodeVideo(0,bgrScreen,(System.nanoTime() - startTime)- totalPauseTime,TimeUnit.NANOSECONDS);
                } else {
                    writer.encodeVideo(0,System.nanoTime() - startTime,TimeUnit.NANOSECONDS);
                }




                // sleep for frame rate milliseconds
                try {
                    Thread.sleep((long) (1000 / FRAME_RATE));
                } catch (InterruptedException e) {
                    // ignore
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    try {
        writer.close();
        writer = null;
        Runtime.getRuntime().gc();
    } catch (Exception e) {
        // ignore errors
    }
    // tell the writer to close and write the trailer if needed

}

public static BufferedImage convertToType(BufferedImage sourceImage,int targetType) {

    BufferedImage image;

    // if the source image is already the target type,return the source
    // image
    if (sourceImage.getType() == targetType) {
        image = sourceImage;
    }
    // otherwise create a new image of the target type and draw the new
    // image
    else {
        image = new BufferedImage(sourceImage.getWidth(),sourceImage.getHeight(),targetType);

        if (true) {
            int x = MouseInfo.getPointerInfo().getLocation().x - 25;
            int y = MouseInfo.getPointerInfo().getLocation().y - 37;

            Graphics2D graphics2D = sourceImage.createGraphics();// getGraphics().drawImage(m_MouseIcon,// x,y,48,null);
            graphics2D.drawImage(SimpleWebBrowserExample.m_MouseIcon,x,null);
        }
        image.getGraphics().drawImage(sourceImage,null);

    }
    return image;
}

private BufferedImage getDesktopScreenshot() {
    try {
        // Robot captures screen shot
        Robot robot = new Robot();
        Rectangle captureSize = new Rectangle(screenBounds);
        return robot.createScreenCapture(captureSize);
    } catch (AWTException e) {

        e.printStackTrace();
        return null;
    }

}  
音频捕获代码:
  public void run() {

        init();
        DataLine.Info info = new DataLine.Info(TargetDataLine.class,audioFormat,(int) (m_AudioFreq * sampleSizeInBytes));


        try 
        {
            m_TargetLine = (TargetDataLine) AudioSystem.getLine(info);
            m_TargetLine.open(audioFormat,info.getMaxBufferSize());
        } 
        catch(Exception exp){
            exp.printStackTrace();
        }


    AudioFileFormat.Type targetType = AudioFileFormat.Type.WAVE;

    try 
    {
        m_outputFile = new File(bufferFileName);
        while (m_outputFile.exists() && !m_outputFile.delete())
        {
            m_outputFile = BerylsUtility.getNextFile(m_outputFile);
        }

        FileOutputStream outFileStream = new FileOutputStream(m_outputFile);
        audioOutStream = new BufferedOutputStream(outFileStream,memoryBufferSize);
    } 
    catch (FileNotFoundException fe){

        System.out.println(\"FileNotFoundException in VoiceCapturing.java :: \" + fe);
    } 
    catch (OutOfMemoryError oe){

        System.out.println(\"OutOfMemoryError in VoiceCapturing.java \" + oe);
    }

    while (isStopProceesBtnClk) {
        try {

            if (!isStopProceesBtnClk) {
                break;
            } else {
                synchronized (this) {
                    while (isPauseProceesBtnClk) {
                        try {                               
                            wait();
                        } catch (Exception e) {
                            e.printStackTrace();
                        }
                    }
                }
                try 
                {
                    m_TargetLine.start();
                    int cnt = m_TargetLine.read(tempBuffer,tempBuffer.length);
                    if(cnt > 0){
                        audioOutStream.write(tempBuffer,cnt);
                    }

                } 
                catch (Exception e){                
                    System.out.println(\"Exception in VoiceCapturing.java :: \" + e);
                } 
                /*finally{
                    finish();
                }*/
            }
        } catch (Exception e) {

            e.printStackTrace();
        }
    }
    finish();
}


public synchronized void finish() 
{

    try 
    {
        System.out.println(\"AudioFinish\");
        audioOutStream.close();
        FileInputStream audioInAgain = new FileInputStream(m_outputFile);
        long sampleBytes = m_outputFile.length();
        long sizeOfFrame = (long) m_SampleRate * m_Channels / 8;
        BufferedInputStream buffAudioIn = new BufferedInputStream(audioInAgain,memoryBufferSize);
        AudioInputStream a_input = new AudioInputStream(buffAudioIn,sampleBytes / sizeOfFrame);
        while (m_AudioFile.exists() && !m_AudioFile.canWrite()) 
        {
            m_AudioFile = BerylsUtility.getNextFile(m_AudioFile);
        }
        AudioSystem.write(a_input,m_targetType,m_AudioFile);
        buffAudioIn.close();
        m_outputFile.delete();
    } 
    catch (Exception e) 
    {
        e.printStackTrace();
    }
}
有人可以指导我吗... 谢谢。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-