将B站视频设置为浏览器背景,你确定不试试?

简介: 将B站视频设置为浏览器背景,你确定不试试?

动图效果

说在前面

心血来潮做了个插件,通过该插件我们使用B站视频来做自己浏览器网页的背景视频,这样浏览起来是不是会更加的赏心悦目。

使用步骤

插件下载

Gitee地址:https://gitee.com/zheng_yongtao/chrome-plug-in/tree/master/Chrome-backGroundVideo

CSDN插件:https://download.csdn.net/download/Twinkle_sone/22003790

添加扩展程序

打开链接 chrome://extensions/ 进入扩展程序管理页面,将下载解压的文件夹拉入这里即可,如下图,第一个插件即为我们新加的插件。

使用

添加完成之后,页面上会有扩展程序的小图标,点击这个小图标,会弹出一个窗口

在这个窗口输入视频链接后,我们就可以使用该视频作为网页背景了,那么问题来了,这个视频链接要去哪里获取呢?

获取链接

我们先随便在B站上打开一个视频,视频下方会有一个分享按钮。

点击按钮后会出现两个链接,我们只需要复制我们需要的链接即可,如下图:

将这个链接放进输入框后点击确认,我们会发现视频出来了,如下图:

但是视频播放不了,这是因为浏览器限制了视频自动播放,所以我们还需要稍微的手动一下,我们看到了页面左边有个粉粉的按钮,点击它会有什么效果呢?

点击了之后我们可以看到视频的层级就跑到了最上层来了,我们就可以点击到播放按钮了,所以我们只需要切换层级点击播放之后再切换层级回去就可以实现开头动图的效果了(不会有人嫌麻烦吧,(╥╯^╰╥)流泪)。

代码分析

获取视频链接
chrome.runtime.onConnect.addListener((res) => {
    // console.log('contentjs中的 chrome.runtime.onConnect:',res)
    if (res.name === 'myConnect') {
        res.onMessage.addListener(mess => {
            console.log('popup中 res.onMessage.addListener:', mess)
            mess = iframeSrcSplit(mess);
            createIframe(mess)
        })
    }
})
解析视频链接
function iframeSrcSplit(iframeSrc){
    let temp = iframeSrc.split('src="')[1];
    iframeSrc = temp.split('" ')[0];
    //弹幕
    iframeSrc += '&danmaku=0' //+ (this.danmaku ? 1 : 0)
    //画质
    iframeSrc += '&high_quality=1'
    //自动播放
    // iframeSrc += '&autoplay=true'
    //循环
    iframeSrc += '&loop=true'
    return iframeSrc;
}
创建iframe并插入
function createIframe(iframeSrc){
    let body = document.getElementsByTagName('body')[0];
    body.style.opacity = 0.8;
    let iframe = document.createElement('iframe');
    iframe.muted = true
    iframe.src = iframeSrc;
    localStorage.setItem('iframeSrc',iframeSrc);
    iframe.id = 'BiliVideo';
    iframe.name = 'BiliVideo';
    iframe.style.width = '100%'
    iframe.style.height = '100%'
    iframe.style.position = 'fixed'
    body.before(iframe)
    iframe.style.zIndex = '100'
}
生成按钮
function btnGenerator(){
    let ghtml = document.getElementsByTagName('html')[0],
        gdiv = document.createElement('div');
    gdiv.id = 'changdiv'
    gdiv.style.position = 'fixed';
    gdiv.style.width = '100%';
    gdiv.style.height = '100%';
    gdiv.style.top = '0px';
    gdiv.style.left = '0px';
    gdiv.style.opacity = '0.7';
    gdiv.style.zIndex= '-1';
    ghtml.appendChild(gdiv);
    //页面上的切换按钮
    let gBtn = document.createElement('div');
    gBtn.id = 'gBtn';
    gBtn.innerText = "切换层级";
    gBtn.style.opacity = "0.6";
    gBtn.style.position = "fixed";
    gBtn.style.right = "40px";
    gBtn.style.top = "50%";
    gBtn.style.border = "solid black 1px"
    gBtn.style.width = "80px";
    gBtn.style.height = "80px";
    gBtn.style.borderRadius = "50% 50%";
    gBtn.style.lineHeight = "80px";
    gBtn.style.textAlign = "center";
    gBtn.style.backgroundImage = "linear-gradient(#e66465, #9198e5)";
    gBtn.style.fontSize = "initial";
    gBtn.style.cursor = "pointer";
    gBtn.style.zIndex = "999";
    ghtml.appendChild(gBtn);
    $("#gBtn").hover(function(){
        let w = parseInt($("#gBtn").css("left"));
        if(w == windowWidth-20){
            $("#gBtn").css({"left":windowWidth-80});
        }
    },function(){
        let w = parseInt($("#gBtn").css("left"));
        if(w >= windowWidth-80){
            $("#gBtn").css({"left":windowWidth-20});
        }
    });
    //按钮拖拽功能
    $("#gBtn").mousedown(function(e){
        gmove=true;
        startX = e.pageX
        startY = e.pageY
        // console.log("move",gmove);
        _gx=e.pageX-parseInt($("#gBtn").css("left"));
        _gy=e.pageY-parseInt($("#gBtn").css("top"));
    });
    $(document).mousemove(function(e){
        if(gmove){
            var x=e.pageX-_gx;//控件左上角到屏幕左上角的相对位置
            var y=e.pageY-_gy;
            $("#gBtn").css({"top":y,"left":x});
        }
    }).mouseup(function(e){
        endX = e.pageX;
        endY = e.pageY;
        let d = Math.sqrt((startX - endX) * (startX - endX) + (startY - endY) * (startY - endY));
        if (d === 0 || d < 7) {
            // console.log("执行了点击事件");
            let iframe = document.getElementById('BiliVideo');
            if(iframe.style.zIndex == '-1'){
                iframe.style.zIndex = '100'
            }else{
                iframe.style.zIndex = '-1'
            }
        } else {
            // console.log("执行了拖拽事件");
            if(windowWidth - endX < 60){
                $("#gBtn").css({"left":windowWidth-20});
            }
        }
        gmove=false;
    });
}

代码地址

Gitee:https://gitee.com/zheng_yongtao/chrome-plug-in/tree/master/Chrome-backGroundVideo

(喜欢的可以点个星,呜呜呜)

更多插件

浏览器网页背景换肤插件

浏览器桌面挂件动画插件

B站视频评论屏蔽插件

鼠标点击烟花效果,妹子看后直说酷

目录
相关文章
|
15天前
|
编解码 JavaScript
【vue2】vue2 适配pc端,解决浏览器缩放问题,解决电脑显示设置缩放、分辨率问题
【vue2】vue2 适配pc端,解决浏览器缩放问题,解决电脑显示设置缩放、分辨率问题
17 1
|
8天前
|
安全
Linken Sphere指纹浏览器中的IPXProxy代理IP设置技巧
大家想要浏览全球资源的时候,往往会遇到很多的阻碍,学会使用指纹浏览器能解决大家不少的烦恼。Linken Sphere指纹浏览器允许配置代理IP,并使用不同的用户代理,不过有些用户不知道该如何进行代理IP的配置。下文就教会大家如何在Linken Sphere指纹浏览器中设置IPXProxy代理IP。
|
1月前
技术经验分享:360浏览器截图快捷键设置
技术经验分享:360浏览器截图快捷键设置
16 0
技术经验分享:360浏览器截图快捷键设置
|
2月前
|
XML Android开发 数据格式
使用默认闪电浏览器 全屏播放视频时有黑边
使用默认闪电浏览器 全屏播放视频时有黑边
44 5
|
2月前
谷歌浏览器跨域设置都是127.0.0.1出现跨域
谷歌浏览器跨域设置都是127.0.0.1出现跨域
93 0
|
2月前
|
JavaScript
浏览器插件crx文件--JS混淆与解密
浏览器插件crx文件--JS混淆与解密
81 0
|
2月前
|
Web App开发 JavaScript 前端开发
浏览器与Node.js事件循环:异同点及工作原理
浏览器与Node.js事件循环:异同点及工作原理
|
1月前
|
Web App开发 JavaScript 前端开发
使用 JS 实现在浏览器控制台打印图片 console.image()
在前端开发过程中,调试的时候,我们会使用 console.log 等方式查看数据。但对于图片来说,仅靠展示的数据与结构,是无法想象出图片最终呈现的样子的。 虽然我们可以把图片数据通过 img 标签展示到页面上,或将图片下载下来进行预览。但这样的调试过程实在是复杂,何不实现一个 console.image() 呢?
38 1
使用 JS 实现在浏览器控制台打印图片 console.image()
|
22天前
|
JavaScript
js中readAsDataURL的意思,可以用于浏览器预览图像文件或者转成base64字符串
js中readAsDataURL的意思,可以用于浏览器预览图像文件或者转成base64字符串
js中readAsDataURL的意思,可以用于浏览器预览图像文件或者转成base64字符串
|
1月前
|
JavaScript
JS获取浏览器地址栏的多个参数值的任意值
JS获取浏览器地址栏的多个参数值的任意值
24 3

热门文章

最新文章