grid 固定宽高比,处理视频适配

接水怪

共 2450字,需浏览 5分钟

 ·

2021-11-29 12:27

需求背景

最近接到一个需求,需要重构下面的宫格,由于宫格不是16:9,导致 webrtc 拉出来的流,渲染到宫格中的时候,视图会填充不满,客户体验不好(因为客户很多都是要投大屏)。

改造前:可以明显看到 grid 上下有留白,最开始做的 hack 是给 video 设置 object-fit: fill; 但是视图会被拉伸。

所以,这样肯定是不行的。那要怎么实现固定比例,从而不留白呢?分两步走。

第一步,单个容器固定宽高比

思路就是把容器的 height 设置为 0,然后设置 padding-top/padding-bottom 为 56.25%(9/16)


  <head>
    <style>
      .wrapper {
        width30vw;
      }
      .container {
        width100%;
        height0;
        padding-top56.25%;
        background-color#002fa7;
        position: relative;
      }
      .content {
        position: absolute;
        left0;
        top0;
        width100%;
        height100%;
        display: flex;
        align-items: center;
        justify-content: center;
        color#fff;
      }
    
style>

  head>
  <body>
    <div class="wrapper">
      <div class="container">
        <div class="content">内容区域div>

      div>
    div>
  body>
</html>

第二步,grid 布局固定宽高比

这次先上图:基于 grid,实现上图。可以发现,容器的宽高比为 3x:3y,那么根据前面的思路,我只要保证容器的宽高比为 16:9, 就能保证 nx:ny=16:9。

上代码:


  <head>
    <style>
      .wrapper {
        width30vw;
      }
      .container {
        width100%;
        height0;
        padding-top56.25%;
        background-color#002fa7;
        position: relative;
      }
      .content {
        position: absolute;
        left0;
        top0;
        width100%;
        height100%;
        display: grid;
      }
      .content div {
        border1px solid gray;
        color#fff;
        display: flex;
        align-items: center;
        justify-content: center;
      }
      .grid_1 {
        grid-area1 / 1 / 3 / 3;
      }
      .grid_2 {
        grid-area1 / 3 / 2 / 4;
      }
      .grid_3 {
        grid-area2 / 3 / 3 / 4;
      }
      .grid_4 {
        grid-area3 / 1 / 4 / 2;
      }
      .grid_5 {
        grid-area3 / 2 / 4 / 3;
      }
      .grid_6 {
        grid-area3 / 3 / 4 / 4;
      }
    
style>

  head>=
  <body>
    <div class="wrapper">
      <div class="container">
        <div class="content">
          <div class="grid_1">2x:2ydiv>

          <div class="grid_2">x:ydiv>
          <div class="grid_3">x:ydiv>
          <div class="grid_4">x:ydiv>
          <div class="grid_5">x:ydiv>
          <div class="grid_6">x:ydiv>
        div>
      div>
    div>
  body>
</html>

💡:假如 grid 语法不熟,https://cssgrid-generator.netlify.app/ 这个网站可以在线生成 grid 代码。

aspect-ratio

基于 css 原生属性 aspect-ratio (兼容性会有一定的限制)实现。例如实现一个 4:3 的容器:


  <head>
    <style>
      .wrapper {
        width30vw;
      }
      .container {
        width100%;
        aspect-ratio4/3;
        background-color#002fa7;
        display: flex;
        align-items: center;
        justify-content: center;
        color#fff;
      }
    
style>

  head>
  <body>
    <div class="wrapper">
      <div class="container">4:3div>

    div>
  body>
</html>

最后,上成果

可以看到,webrtc 拉出来的 16:9 的流,跟宫格完全贴合。

后续有时间,也可以分享 webrtc 相关,以及视频 video 相关操作。比如常见的视频截图、录屏、进度条等。

浏览 87
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报