开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 3972|回复: 118
收起左侧

[2025开源大赛(第八届)] WebView2透明窗口效果(用Web做UI)

[复制链接]
发表于 2025-10-7 15:25:18 | 显示全部楼层 |阅读模式   重庆市重庆市
分享源码
界面截图: -
是否带模块: -
备注说明: -
本帖最后由 hxznhf 于 2025-10-7 16:21 编辑

QQ20251007-144702.png


本例子使用了kyozy大佬的黑月界面模块和WebView2模块,都是大佬开源的,论坛都有源代码,感谢大佬的无私奉献!!!

本例子仅限于最新的Window10或11,以及最新的WebView2运行时,具体适用版本我未cha询。因为涉及到的特性和接口都比较新。



一、创建窗口用于放置WebView2控件

【窗口风格】需设置弹出式窗口,【扩展风格】需设置WS_EX_NOREDIRECTIONBITMAP

WS_EX_NOREDIRECTIONBITMAP:0x00200000L
窗口不会呈现到重定向图面。 这适用于没有可见内容的窗口,或者使用表面以外的机制来提供其视觉对象。

这个样式是实现WebView2控件与Win32窗口透明混合渲染的核心,有了它,Windows系统会自己实现最终透明混合效果(意料之外,理论是需要更加复杂的处理)

  
应用.初始化 ()
主窗口.置开始位置 ( #开始位置_居中屏幕 )
主窗口.事件_创建完毕 (&窗口事件_创建完毕)
主窗口.事件_尺寸被改变 (&窗口事件_尺寸改变)
主窗口.创建W (, , , 黑月坐标 (800, 600), #窗口风格_弹出式窗口, #WS_EX_NOREDIRECTIONBITMAP )
主窗口句柄 = 主窗口.取窗口句柄 ()
窗口控制.创建 ()
应用.运行 (主窗口)


二、创建WebView2控件并加载界面(HTML)

核心点:
1、--enable-features=msWebView2EnableDraggableRegions  启用一个WebView2实验性功能(与后面窗口拖动相关)
1、使用控制器设置默认背景色 (到整数 ({ 0, 0, 0, 0 }))  //这里设置网页的默认背景为透明
2、绑定一个COM类(在WebView2模块中叫主机对象,必须继承它),用于窗口交互控制,当然也可以使用WebView2自带的消息通知接口实现(这个比较简单,就不写了)

  
子程序名返回值类型公开备 注
窗口事件_创建完毕  
参数名类 型参考可空数组备 注
hWnd整数型
变量名类 型静态数组备 注
optWebView2环境选项 
opt.创建 ()
opt.置附加浏览器参数 (“--enable-features=msWebView2EnableDraggableRegions”)
WV2创建环境自选项 (&子程序_创建环境完毕, , , , opt)
子程序名返回值类型公开备 注
子程序_创建环境完毕整数型 
参数名类 型参考可空数组备 注
参数_用户数据整数型
参数_错误代码整数型
参数_环境指针整数型
变量名类 型静态数组备 注
env4WebView2环境4 
集_环境.置指针 (参数_环境指针)
集_环境.创建控制器 (主窗口.取窗口句柄 (), &子程序_创建控制器完毕)
' 如果真 (集_环境.转换为 (#IID_WebView2环境4, env4) = 0)
' 输出调试文本 (env4.取浏览器版本 ())
返回 (0)
子程序名返回值类型公开备 注
子程序_创建控制器完毕整数型 
参数名类 型参考可空数组备 注
参数_用户数据整数型
参数_错误代码整数型
参数_控制器指针整数型
变量名类 型静态数组备 注
token长整数型 
setingWebView2设置 
控制器2WebView2控制器2 
集_控制器.置指针 (参数_控制器指针)
集_控制器.取视图 (集_视图)
集_控制器.转换为 ( #IID_WebView2控制器2, 控制器2)
控制器2.置默认背景色 (到整数 ({ 0, 0, 0, 0 }))
集_控制器.置边界 (0, 0, 主窗口.宽度 (), 主窗口.高度 ())
集_视图.添加主机对象到脚本 (“window”, 窗口控制)
集_视图.导航 (“file:///”取运行目录 ()“/test.html”)
返回 (0)



三、界面(HTML)实现

参考资料:
https://github.com/MicrosoftEdge/WebView2Feedback/issues/2243

核心点:
1、app-region: drag;  这是去年新增的WebView2专用的CSS属性,用于标记一个元素实现对窗口的拖动,必须在创建WebView2环境时带上参数(--enable-features=msWebView2EnableDraggableRegions)来启用这个功能。在易语言里面还需要使用 "WebView2设置9.置是否启用非客户区支持 (真)" 才能完全起作用(不过我在C++测试时没启用也能拖动)。【2025年10月7日16点18分修改】


[JavaScript] 纯文本查看 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>测试</title>
</head>
<body >

    <style>
        html,body{
            background-color: transparent;
            width: 100%;
            height: 100%;
        }
        body {
            font-family: Arial, sans-serif;
            margin: 20px;
            overflow: hidden;
            background-color: #ababab72;
        }
        h1 {
            color: #333;
        }
        p {
            font-size: 16px;
        }
        button {
            padding: 10px 15px;
            font-size: 16px;
            cursor: pointer;
        }
        content{
            border: 2px solid #ccc;
            width: 80%;
            padding: 20px;
            border-radius: 5px;
            box-shadow: 2px 2px 12px rgba(0,0,0,0.1);
        
        }
        .titleBar{
            user-select: none;  
            app-region: drag;
            background-color: #f0f0f0;
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 30px;
            background-color: #333;
      
            color: white;
        }
    </style>
        <div class="titleBar">webview2透明窗口 </div>
        <div class="closeBtn" style="position:absolute;top:0;right:0;width:30px;height:30px;line-height:30px;text-align:center;cursor:pointer;background-color:#ff4d4d;color:white;font-weight:bold;">X</div>
        <br><br><br><br><br>
    <div class="content">
    
        <h1>这是一个测试页面</h1>
        <p>用于测试WebView2控件的嵌入。</p>
        <button>点击我</button>
    </div>
    
</body>


</html>



附件中除了(WebView2Loader.dll)是微软官方提供的,因为易语言不方便使用静态库,只能用这个,其他都是源代码(包含引用的kyozy模块)。
2025年10月7日16点19分: 更新了附件

附件:
游客,如果您要查看本帖隐藏内容请回复




评分

参与人数 6好评 +3 精币 +14 收起 理由
文西哥 + 1 感谢分享,很给力!~
cui870222829 + 1 感谢分享,很给力!~
steve + 1 支持开源~!感谢分享
外星人群控 + 1 + 5 新技能已get√
lao3 + 1 + 3 支持开源~!感谢分享
雨落无声 + 1 + 3 YYDS~!

查看全部评分


本帖被以下淘专辑推荐:

  • · 鱼木|主题: 1613, 订阅: 157
结帖率:95% (186/196)

签到天数: 3 天

发表于 2 小时前 | 显示全部楼层   福建省福州市
66666666666666666666666666
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 4 小时前 | 显示全部楼层   河北省衡水市
如果您要查看本帖隐藏内容请回复
回复 支持 反对

使用道具 举报

签到天数: 11 天

发表于 4 小时前 | 显示全部楼层   广东省韶关市
6666666666666666666
回复 支持 反对

使用道具 举报

结帖率:75% (6/8)

签到天数: 3 天

发表于 昨天 22:49 | 显示全部楼层   江西省九江市
为爱发电
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 3 天

发表于 昨天 15:28 | 显示全部楼层   福建省厦门市
看看               
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 前天 18:11 | 显示全部楼层   四川省眉山市
#在这里快速回复#2025年10月7日16点19分: 更新了附件
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 13 天

发表于 前天 16:40 | 显示全部楼层   陕西省汉中市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 16 天

发表于 前天 11:45 | 显示全部楼层   广东省广州市
多谢分享哦。。
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)

签到天数: 2 天

发表于 前天 11:11 | 显示全部楼层   安徽省阜阳市
让 江小白 来看看帖子里藏了啥好东西~~~
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

关闭

精易论坛 - 有你更精彩上一条 /2 下一条

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表