tauri自定义窗口window并实现拖拽和阴影效果

需求说明

由于官方提供的窗口标题并不能实现我的需求,不能很好的实现主题切换的功能,所以根据官方文档实现了一个自定义的窗口,官方文档地址:Window Customization | Tauri Apps

但是实现之后, 没有了窗体拖拽移动的功能,,,,,,而且没有边框和阴影,所以就显得特别奇怪,所以今天在这里,我都给你安排上了:

因为录制gif图的工具问题,导致录屏效果不是很好,实现的效果图:

动图效果:

具体实现步骤

1.先实现自定义窗口效果

实现自定义窗口效果非常简单,只需要按照官方文档提示的,在tauri.config.json里面添加一个配置:"decorations": false,然后再打开你的程序,你就会发现,没有了窗口的头部,哈哈哈

        "windows": [
            {
                "label": "customization",
                "fullscreen": false,
                "resizable": true,
                "title": "FileHub",
                "fileDropEnabled": false,
                "width": 1031,
                "height": 580,
                "center": true,
                "decorations": false
            }
        ]

然后就是添加自定义的缩小,全屏,关闭按钮的功能:

其实按照官方文档的来添加也可以,我这里是使用的自己自定义的html内容样式:

html内容:因为我这里用的element-plus,所以用的他们的icon图标,你可以换成官方的内容

<div data-tauri-drag-region class="titlebar">
  <div class="titlebar-button" id="titlebar-minimize">
    <img
      src="https://api.iconify.design/mdi:window-minimize.svg"
      alt="minimize"
    />
  </div>
  <div class="titlebar-button" id="titlebar-maximize">
    <img
      src="https://api.iconify.design/mdi:window-maximize.svg"
      alt="maximize"
    />
  </div>
  <div class="titlebar-button" id="titlebar-close">
    <img src="https://api.iconify.design/mdi:close.svg" alt="close" />
  </div>
</div>

css样式:

.titlebar {
  height: 30px;
  background: #329ea3;
  user-select: none;
  display: flex;
  justify-content: flex-end;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}
.titlebar-button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
}
.titlebar-button:hover {
  background: #5bbec3;
}

然后js代码:

import { appWindow } from '@tauri-apps/api/window'
document
  .getElementById('titlebar-minimize')
  .addEventListener('click', () => appWindow.minimize())
document
  .getElementById('titlebar-maximize')
  .addEventListener('click', () => appWindow.toggleMaximize())
document
  .getElementById('titlebar-close')
  .addEventListener('click', () => appWindow.close())

如果你使用的是vue3,需要在onMounted函数中添加:

import { onMounted } from 'vue'

onMounted(() => {
  document.getElementById('titlebar-minimize')!.addEventListener('click', () => appWindow.minimize())
  document.getElementById('titlebar-maximize')!.addEventListener('click', () => appWindow.toggleMaximize())
  document.getElementById('titlebar-close')!.addEventListener('click', () => appWindow.close())
  console.log("onMounted------", document.getElementById('titlebar-close'));
})

然后效果就出来了:

2.实现拖拽效果

拖拽效果其实更简单,只需要在你想要的元素上添加属性:data-tauri-drag-region 就可以了,然后你按住这个元素所在区域,就可以拖拽移动了:

3.实现窗口阴影

阴影效果要通过添加一个依赖实现:GitHub - tauri-apps/window-shadows: Add native shadows to your windows.

具体实现步骤:

3.1 给窗口添加label标签:主要是让程序识别到这个窗口

3.2 然后在src-tauri\Cargo.toml中添加依赖

window-shadows = "0.2.1"

3.3 在main.rs程序中引用

在src-tauri\src\下创建utils.rs文件,并添加内容:这里就用到了3.1中添加的customization这个lable窗口标识

use tauri::{Manager, Runtime};
use window_shadows::set_shadow;

pub fn set_window_shadow<R: Runtime>(app: &tauri::App<R>) {
  let window = app.get_window("customization").unwrap();
  set_shadow(&window, true).expect("Unsupported platform!");
}

然后在src-tauri\src\main.rs中引用这个utils.rs:

// Prevents additional console window on Windows in release, DO NOT REMOVE!!
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]

use crate::{
  utils::{set_window_shadow}
};

mod utils;

fn main() {
  tauri::Builder::default()
    .setup(|app| {
      set_window_shadow(app);
      Ok(())
    })
    .invoke_handler(tauri::generate_handler![])
    .run(tauri::generate_context!())
    .expect("error while running tauri application");
}

最后重启应用,就可以看到有阴影效果了:

我的项目中已经使用了,可以查看我的FileHub项目:

GitHub - Sjj1024/s-hub: 一个使用github作为资源存储的软件

相关推荐
m0_7482365831 分钟前
Django 后端数据传给前端
前端·数据库·django
余生H36 分钟前
前端Python应用指南(五)用FastAPI快速构建高性能API
前端·python·fastapi
racerun41 分钟前
Vue vuex.store mapState
前端·javascript·vue.js
2301_8010741544 分钟前
ArkTs组件(2)
开发语言·前端·华为·harmonyos
DT——1 小时前
Sass复习篇
前端·css·sass
m0_748251721 小时前
ollama-webui - Ollama的ChatGPT 风格的 Web 界面
前端·chatgpt
小蒜学长1 小时前
基于Spring Boot的宠物领养系统的设计与实现(代码+数据库+LW)
java·前端·数据库·spring boot·后端·旅游·宠物
这我可不懂1 小时前
低代码开发 实战转型案例一览
前端·低代码·程序员
明月看潮生1 小时前
青少年编程与数学 02-005 移动Web编程基础 06课题、响应式设计
前端·青少年编程·编程与数学·移动web
明月看潮生1 小时前
青少年编程与数学 02-005 移动Web编程基础 07课题、多媒体形式
前端·青少年编程·移动开发·编程与数学·移动web