导航

萌即是正义!时不时分享一些ACG活动记录与有趣代码的小站!

侧边栏
热门文章
1页面
程序员老黄历&求签
热度
494
2推文
一开始还以为是2.5次元的舞台剧,结果仔细一看是音乐剧!?有一丢丢的兴趣,到时候看看能不能搞到门票。 《FateZero》真人音乐剧 定妆照预告:https://www.bilibili.com/video/BV1RqSoYmEzJ
热度
207
3博文
《孤独摇滚》圣地巡礼——下北泽&下北泽咖喱节2023
热度
104
4博文
探访《蜡笔小新》老家——春日部游记
热度
91
5推文
知道这套道具的人年纪应该都不小了吧。
热度
65
6博文
如何使用ffmpeg.wasm在浏览器前端实现视频压缩和剪辑
热度
65
7博文
Live2d模型合集分享 | FaceRig | 海王星系列 | 初音未来 | 雷姆 | 凉风青叶 | 尼禄 | 薇尔莉特 | 小埋 | 樱花庄 | 玉藻前
热度
65
8推文
刚发完对《冒险岛Online》R区的遗憾没多久,韩服那边又开始搞事情了,做出了如下的修改: 1、删除持有金币,主要消耗、其他道具; 2、可使用拍卖、个人件交易、金币市场功能; 3、装备卷轴强化和可用附加潜能,但是该效果在3个月内不生效,R区的终伤BUFF仍旧保存3个月; 4、删除R区被动中BOSS装备掉率增加属性等全部属性; 5、现有装备道具均变为永久不可交易道具。 ※主要删除道具:金币、红魔方、黑魔方、痕迹、强大火花、核心宝石、可获得装备的部分消耗道具、可通过金币购买的道具等。 这可真是至R区于死地啊...要说修改游戏的模式也就算了,现在不仅没有任何补充,还把先前的劳动成果给删除了是不是太过分了!? 日服到时候肯定二话不说跟进,国际服那边如果没了韩服对R区的技术支持,个人觉得服软也是时间的问题。
热度
52
9博文
谈谈这次《冒险岛Online》日服R区的削弱事件
热度
52
10博文
文石BOOX Leaf2使用感想
热度
52
最新评论
广树
2024-11-21 16:04
@hikari:BGM也许是吧,歌曲部分感觉不一定
hikari
2024-11-21 09:52
居然是音乐剧!真是没想到,难道说会用梶浦大妈的配乐吗?看预告片里就用的是fz里最扣人心弦的bgm。🥰
广树
2024-11-20 08:18
@石樱灯笼:这应该是受众的年龄层的问题吧
石樱灯笼
2024-11-20 06:57
@广树:承太郎抽根烟,整张嘴都被打码。
广树
2024-11-20 06:48
@石樱灯笼:不是挺符合人设吗?为什么会离谱?
正在攻略

logo_kai.jpg


PSN奖杯卡

PSN奖杯卡

赞助商广告

记录iOS 17.4.1 Safari 本地视频无法正常显示的2个问题

作者:广树时间:2024-04-05 20:16:50分类:前端代码

最近发现2个Safari比较棘手的本地视频播放的问题,目前没有特别有效的规避方法,等待苹果官方的修正可能是最优解,所以打算通过这篇博文实时记录一下进展。


以下问题都仅在iPhone和iPad中出现,mac暂时没有发现。

所有问题均写了一个demo发布在了github上: https://github.com/eeg1412/safari-video-bug

同时为了方便演示,开启了github pages : https://eeg1412.github.io/safari-video-bug/

问题一:路由切换时本地视频会中断

问题描述

总所周知现在的前端代码都是通过 window.history.pushState(null, '', url) 来实现不刷新页面来切换页面的,这就使视频在切换路由时仍然能保持播放。

但是发现17.4.1之后,在切换路由后就会导致摄像头捕捉中断。

在演示代码中可以看见点击change history按钮后,路由发生变化,视频变成了黑屏,摄像头捕捉中断。

幸运的是目前这个问题并没有殃及一般视频的播放,仅仅影响摄像头的捕捉播放。

这个问题在今年年初就有人向官方反馈,beta版有这个BUG,正式版依然没有修😅。

解决方案

这个问题我目前的解决方案是把history模式改成hash模式。


问题二:视频元素中的内容不会跟随video标签的宽高变化而变化

问题描述

这个问题是比较神奇的一个现象,因为要触发条件比较苛刻,我大致归类了以下条件会触发:

  1. 视频播放本地摄像头
  2. 父级display从blog->flex
  3. video标签附近要有个img标签
  4. 似乎和img的尺寸也有关系?有些尺寸偶发,有些尺寸很难复现,有些尺寸很容易复现

我觉得最神奇的一点是附近必须要有一张大小合适的图片😅。最近可能比较倒霉,这么苛刻的条件都能给我遇上😅。

在演示网站中的效果如下:

可以看到红色区域是video元素,虽然video的宽高变了,但是内容始终保持原来的大小。

这个问题我看了下官方的反馈列表,目前并没有人反馈这个问题,于是就向苹果官方反馈了这个问题。

截至目前,官方给我的反馈是无法复现😅。

我看了眼官方的测试案例,苹果将我的代码放到了jsfiddle上进行测试,确实就复现不出来了。

后来我发现,如果内容是在<iframe>中运行的话确实就复现不出来了,很神奇。这才又建立了github pages,让苹果的技术人员通过github pages进行测试。

因为苹果官方和我有时差,通过邮件来回基本上也只能一天沟通一次,所以后续进展如何会更新在这里,敬请期待!

如果大家有兴趣的话,也可以用苹果手机试一试。

以下是复现步骤:

  1. 在iPhone(iOS 17.4.1)上打开链接:https://eeg1412.github.io/safari-video-bug/
  2. 允许摄像头访问。
  3. 等待相机画面出现在屏幕上。
  4. 单击摄像机源以更改视频的大小。

解决方案

这个问题我目前的解决是将原先的block->flex改成block->none->flex,进行强行重新渲染。


2024年5月4日更新:

官方已经修复【视频元素中的内容不会跟随video标签的宽高变化而变化】的问题

https://github.com/WebKit/WebKit/pull/28125

#safari

donate.png

1210 x 50(蓝底).png

cloudcone