1.easyv大屏(pageA)中用了Iframe组件,iframe内嵌套着客户自己写的页面(pageB)。
2.pageB调用了某些大厂的监控播放器插件,这些插件不属于页面dom,是一个exe程序,直接覆盖在页面上层,通过插件内部的api,可以被pageB唤起、销毁、缩放、移动。
3.由于pageA存在transform:scale()进行了缩放,导致pageB中的监控插件发生了位置偏移。
由于pageA和pageB不属于同一个域,存在跨域问题,pageB无法直接获取到pageA中的dom缩放信息,所以pageA只能通过postMessage来把缩放信息和iframe的页面坐标(left和top)发送给pageB,而pageB需要监听message事件,来接收pageA发过来的消息,postMessage的具体使用方法详见MDN:https://developer.mozilla.org/zh-CN/docs/Web/API/Window/postMessage
1.在pageA中,给Iframe组件添加一个自定义事件,如下图所示:
2.代码逻辑如下:
const dom = document.getElementById("bigscreen-container"); //该dom上存在缩放系数
if(dom){
const transform = dom.style.transform;
const scale = transform?transform.match(/^scale\((.+)\)$/)[1]:"1,1"; //利用正则获取缩放值字符串
const arr = scale.split(","); //将逗号作为分隔符,将字符串转换成数组,如果数组只有一个元素,则表示x,y缩放值相同,如果有两个元素,第一个表示x方向的缩放值,第二个是Y方向上的
return {
scale:arr, //页面的缩放系数数组
left:xxx, //iframe的left坐标,直接从组件样式面板中获取,写死
top:xxx //iframe的top坐标,直接从组件样式面板中获取,写死
}
}
return {
scale:1,
left:0,
top:0
};
3.上述代码中,left和top的值是从iframe的样式面板中获取的。
4.在pageB中,通过监听message事件,可以获取到传过来的这个对象
{
parentInfo:{
scale:[0.8],
left:522,
top:114
}
}
5.根据父页面的坐标值和缩放比,我们可以计算出真正的插件坐标:
真正的left = (插件位于pageB中的left + 父页面传过来的left ) / 缩放系数
真正的top = ( 插件位于pageB中的top + 父页面传过来的top ) / 缩放系数
注* 具体算法我也记不清了,大致应该是这样的,如果有些瑕疵,可以调整加减乘除的逻辑,但需要的参数肯定是这几个。
文章
3.46K人气
8粉丝
1关注
©Copyrights 2016-2022 杭州易知微科技有限公司 浙ICP备2021017017号-3 浙公网安备33011002011932号
互联网信息服务业务 合字B2-20220090