IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> aardio设置透明窗体说明 -> 正文阅读

[游戏开发]aardio设置透明窗体说明

废话不多说,直接开干!
窗体透明一般事plus
import win.ui;
/*DSG{{*/
var winform = win.form(text="透明题栏";right=286;bottom=176;border="none")
winform.add(
button={cls="button";text="提交";left=176;top=87;right=231;bottom=108;z=3};
edit={cls="edit";text="Edit";left=86;top=55;right=234;bottom=76;edge=1;z=2};
static={cls="static";text="用记名";left=37;top=56;right=109;bottom=77;transparent=1;z=1}
)
/*}}*/

//给窗体设置背景
import inet.http;//加上http
winform.image = "https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fhbimg.huabanimg.com%2F1c6b595acfd6652b9a080110a0f7b6fc5a94ee33513d-qdBaTS_fw658&refer=http%3A%2F%2Fhbimg.huabanimg.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1654231490&t=169f387371bd97076777e269d07668fc";

//显示窗体
winform.show()
win.loopMessage();

窗体透明化之后,里面的控件脱离原来的窗口显示在窗体外面之后怎么还原回去?

我建立了一个窗口,里面与一个背景色为蓝色的plus. 我设置了窗口透明度是80,然后里面的控件plus也透明化了.

用到代码

winform.plus.orphanWindow();

plus的父窗体为winform.

win.setParent(winform.plus.hwnd,winform.hwnd);

plus控件确实再一次透明化了,但是发现它的位置不是在原来的地方.
再设置plus相对winform位置…

var x,y = winform.plus.getPos();
var bx,by = win.toClient(winform.hwnd,x,y)

win.setParent(winform.plus.hwnd,winform.hwnd);
winform.plus.setPos(bx,by);

运行后,确实透明化在原来的地方.
按钮事件,可在图形编辑视图下,双击按钮快速自动生成
但,问题又来了. 拖动窗口发现,这个plus不是随着窗体移动相对窗口静止,而是随着移动窗口移动的更大幅度
看下完整代码

import win.ui;
//设置窗体透明度
/*DSG{{*/
var winform = win.form(text="aardio form";right=759;bottom=469)
winform.add(
button={cls="button";text="button";left=86;top=372;right=253;bottom=429;z=3};
button2={cls="button";text="button2";left=462;top=356;right=613;bottom=427;z=4};
//设置透明度
edit={cls="edit";text="白叔King";left=93;top=90;right=328;bottom=125;edge=1;font=LOGFONT(h=-21);multiline=1;z=1};
plus={cls="plus";left=105;top=172;right=567;bottom=240;bgcolor=15780518;z=2}
)
/*}}*/

import console;
console.open();

winform.button2.oncommand = function(id,event){
        //winform.msgbox( winform.button2.text );
/*
        console.dump(
                win.getPos(winform.plus.hwnd,true)
        )
        console.dump(
                winform.plus.getPos()
        )
*/
        var x,y = winform.plus.getPos();
        var bx,by = win.toClient(winform.hwnd,x,y)

        win.setParent(winform.plus.hwnd,winform.hwnd);
        winform.plus.setPos(bx,by);
        
}


winform.button.oncommand = function(id,event){
        //winform.msgbox( winform.button.text );
        
        winform.edit.orphanWindow();
        winform.plus.orphanWindow();
}


winform.transparent(80);

winform.show() 
win.loopMessage();

看下效果截图
初次运行安装对应库
在这里插入图片描述

给电脑添加透明护眼蒙版(鼠标穿透) 以上代码参考了, win.ui.mask库里的代码

其实还是可以直接用这个库来实现,上面就是为了学习

要想改变蒙版的颜色, 就把窗口背景色改一改就可以了

看代码

import win.ui;
/*DSG{{*/
var winform = win.form(text="aardio form";right=205;bottom=447;bgcolor=8409088;border="none")
winform.add(
plus={cls="plus";text="半透明写标题";left=0;top=0;right=206;bottom=31;align="left";color=16777215;dl=1;dr=1;dt=1;font=LOGFONT(h=-16);notify=1;textPadding={left=8};z=1}
)
/*}}*/
 
winform.plus.background = 0x33000812;
winform.transparent(60)
winform.plus.orphanWindow(true)
winform.plus.onMouseDown = function(wParam,lParam){
    winform.hitCaption()
     
}
 
import win.ui.shadow
win.ui.shadow(winform);
 
winform.show() 
win.loopMessage();

可以设置尺寸,透明度
看下效果
在这里插入图片描述

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:52:21  更:2022-05-05 11:53:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 1:22:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码