互动应用开发p5.js——音视频交互

简介: 音视频交互一、实验内容:音频可视化,是指一种以视觉为核心,以音频为载体,以大众为诉求对象,借助多种新媒体技术等传播媒介,通过画面、影像来诠释音乐内容的、视听结合的大众化传播方式。它能为理解、分析和比较音频作品形态的表现力和内外部结构提供的一种直观视觉呈现的技术。将麦克风获取到的声音转变成图像获取所需的目标音频信息将振幅转化为波形与环形的振幅其他的是通过声音的大小,获取音频的振幅信息,向绘制圆形的大小参数传递声音振幅的值,以达到不同声音大小的圆形。通过获取音频的振幅信息,将振幅信息传参到小球跳

 音视频交互

一、实验内容:

音频可视化,是指一种以视觉为核心,以音频为载体,以大众为诉求对象,借助多种新媒体技术等传播媒介,通过画面、影像来诠释音乐内容的、视听结合的大众化传播方式。它能为理解、分析和比较音频作品形态的表现力和内外部结构提供的一种直观视觉呈现的技术。

    1. 将麦克风获取到的声音转变成图像
    2. 获取所需的目标音频信息
    3. 将振幅转化为波形与环形的振幅
    4. 其他的是通过声音的大小,获取音频的振幅信息,向绘制圆形的大小参数传递声音振幅的值,以达到不同声音大小的圆形。
    5. 通过获取音频的振幅信息,将振幅信息传参到小球跳高的高度参数,以达到小球不同声音大小时所调高的高度不同。

    主要运用的获取音频信息的函数为mic.getLevel()函数。

    通过像素阵列,进行摄像头影像像素化。利用Pixels数组中存放了每个像素的位置及RGB信息。

    本次实验为自选课题,主题为音视频交互。

    需提交以下内容:

    评价标准:

    音频交互35分 (准确性,难度综合评价)

    视频交互35分(准确性,难度综合评价)

    代码规范10分

    实验报告20分

    二、实验说明:

    所有实验是通过 Visual Studio Code引入p5.js包编写,所以首先要去p5.js官网下载相关包,或是在联网状态下把html中引入包的代码改成例如<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.1.9/p5.js"></script>等。

    三、实验代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="utf-8">
      <title>交互</title>
      <script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.1.9/p5.js"></script>
      <script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.4.0/addons/p5.sound.js"></script>
      <!-- <script src="p5.sound.js"></script> -->
      <!-- <script src="p5.dom.js"></script> -->
    </head>
    <body>
      <script src="sketch.js"></script>
      <!-- <script src="sketch2.js"></script> -->
    </body>
    </html>

    image.gif

    //sketch.js
    //音频交互
    var capture;
    var mic;
    var volhistory=[];
    function setup(){
      // createCanvas(240,180);
      // capture = createCapture(VIDEO);
      let cnv = createCanvas(400, 400);
      // cnv.mousePressed(userStartAudio);
      // textAlign(CENTER);
      angleMode(DEGREES);
      cnv.mousePressed(userStartAudio);
      textAlign(CENTER);
      //amp = new p5.Amplitude();//
      mic = new p5.AudioIn();
      mic.start();
      //amp.setInput(mic);//
    }
    function draw(){
      // image(capture,0,0,width,height);
      //小球跳高
      background(0);
      fill(255);
      text('tap to start', width/2, 20);
      micLevel = mic.getLevel();
      var y = height - micLevel * height;
      ellipse(width/2, y, 10, 10);
      //小球放大
      //background(0);
      //fill(255);
      var vol = mic.getLevel();
      ellipse(100, 100, vol*200, vol*200);
      //横向音频
      volhistory.push(vol);
      stroke(255);
      noFill();
      beginShape();
      for(var i = 0;i<volhistory.length;i++){
        var y = map(volhistory[i],0,1,350,0);
        vertex(i, y)
      }
      if(volhistory.length>width-50){
        volhistory.splice(0,1);
      }
      stroke(255, 0,0);
      line(volhistory.length, 0, volhistory.length, height);
      stroke(255);
      endShape();
      //360度音频
      translate(width/2, height/2);
      beginShape();
      for(var i = 0;i<360;i++){
        var r = map(volhistory[i],0,1,10,100);
        var x = r*cos(i);
        var y = r*sin(i);
        vertex(x, y)
      }
      if(volhistory.length>360){
        volhistory.splice(0,1);
      }
      endShape();
    }

    image.gif

    //sketch2.js
    //视频交互
    var video;
    var vScale = 16;
    function setup() {
      createCanvas(640, 480);
      // capture = createCapture(VIDEO);
      // capture.hide();//图像隐藏
      pixelDensity(1);//高像素密度
      video = createCapture(VIDEO);
      video.size(width / vScale, height / vScale);
    }
    function draw() {
      //黑白图像
      background(51);
      video.loadPixels();
      loadPixels();
      for (var y = 0; y < video.height; y++) {
        for (var x = 0; x < video.width; x++) {
          var index = (x + y * video.width) * 4;
          var r = video.pixels[index + 0];
          var g = video.pixels[index + 1];
          var b = video.pixels[index + 2];
          var bright = (r + g + b) / 3;
          var w = map(bright, 0, 255, 0, vScale);
          noStroke();
          fill(bright);
          rect(x * vScale, y * vScale, w, w);
          pixels[index + 0] = r;
          pixels[index + 1] = g;
          pixels[index + 2] = b;
          pixels[index + 3] = 255;
        }
      }
      // updatePixels();
    }

    image.gif

    sketch.js音频交互;sketch2.js视频交互,需要自行在html文件中修改切换

    四、实验结果:

    image.gif编辑image.gif编辑

    image.gif编辑


    相关文章
    |
    8天前
    |
    数据采集 人工智能 自然语言处理
    Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
    Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
    96 1
    Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
    |
    5月前
    |
    开发框架 JavaScript 前端开发
    揭秘:如何让你的asp.net页面变身交互魔术师——先施展JavaScript咒语,再引发服务器端魔法!
    【8月更文挑战第16天】在ASP.NET开发中,处理客户端与服务器交互时,常需先执行客户端验证再提交数据。传统上使用ASP.NET Button控件直接触发服务器事件,但难以插入客户端逻辑。本文对比此法与改进方案:利用HTML按钮及JavaScript手动控制表单提交。后者通过`onclick`事件调用JavaScript函数`SubmitForm()`来检查输入并决定是否提交,增强了灵活性和用户体验,同时确保了服务器端逻辑的执行。
    59 5
    |
    2月前
    |
    缓存 JavaScript 前端开发
    JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
    本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
    54 5
    |
    2月前
    |
    JSON 前端开发 JavaScript
    聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
    在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
    56 4
    |
    2月前
    |
    设计模式 前端开发 JavaScript
    揭秘!前端大牛们如何巧妙利用JavaScript,打造智能交互体验!
    【10月更文挑战第30天】前端开发领域充满了无限可能与创意,JavaScript作为核心语言,凭借强大的功能和灵活性,成为打造智能交互体验的重要工具。本文介绍前端大牛如何利用JavaScript实现平滑滚动、复杂动画、实时数据更新和智能表单验证等效果,展示了JavaScript的多样性和强大能力。
    61 4
    |
    3月前
    |
    存储 JavaScript 前端开发
    【JavaScript】网页交互的灵魂舞者
    本文介绍了 JavaScript 的三种引入方式(行内、内部、外部)和基础语法,包括变量、数据类型、运算符、数组、函数和对象等内容。同时,文章还详细讲解了 jQuery 的基本语法和常用方法,如 `text()`、`html()`、`val()`、`attr()` 和 `css()` 等,以及如何插入和删除元素。通过示例代码和图解,帮助读者更好地理解和应用这些知识。
    36 1
    【JavaScript】网页交互的灵魂舞者
    |
    4月前
    |
    JavaScript 前端开发
    JavaScript 与 DOM 交互
    【9月更文挑战第01天】
    40 2
    |
    5月前
    |
    JavaScript 前端开发 UED
    Vue.js动画魔法:解锁流畅过渡,让每一次交互都成为用户心中的小确幸!
    【8月更文挑战第30天】在Vue.js中,动画与过渡效果不仅是视觉点缀,更是提升用户体验的关键。通过流畅的动态效果,应用的互动性和吸引力得以增强,从而提高用户满意度和参与度。`&lt;transition&gt;`和`&lt;transition-group&gt;`组件结合CSS过渡,可轻松实现元素的进入、离开及列表变化动画。合理的性能优化,如使用硬件加速,能避免页面卡顿,确保动画既美观又高效。下面是一个简单的淡入淡出效果示例,展示了如何利用Vue.js实现平滑的动画过渡。总之,恰当的动画设计能显著提升应用的用户体验。
    66 0
    Vue.js动画魔法:解锁流畅过渡,让每一次交互都成为用户心中的小确幸!
    |
    5月前
    |
    Devops 持续交付 测试技术
    JSF遇上DevOps:开发流程将迎巨变?一篇文章带你领略高效协同的魅力!
    【8月更文挑战第31天】本文探讨了如何在JavaServer Faces(JSF)开发中融入DevOps文化,通过持续集成与部署、自动化测试、监控与日志记录及反馈机制,提升软件交付速度与质量。文中详细介绍了使用Jenkins进行自动化部署、JUnit与Selenium进行自动化测试、ELK Stack进行日志监控的具体方法,并强调了持续改进的重要性。
    44 0
    |
    5月前
    |
    JavaScript 前端开发 API
    从零开始学表单操作,jQuery 与原生 JavaScript 完全指南,带你轻松掌握网页交互关键!
    【8月更文挑战第31天】在网页开发中,表单是实现用户互动的关键元素。无论是收集信息、提交数据还是验证输入,都需要对表单进行有效操作。本文档介绍了如何使用原生 JavaScript 和 jQuery 操作表单,包括获取表单元素、读写表单值、处理表单提交及验证等核心功能。jQuery 提供了更简洁的语法和更好的兼容性,但原生 JavaScript 在性能上有优势。选择合适的方法取决于项目需求和个人偏好。下面通过具体示例展示了两种方式的操作方法。
    45 0