Electron应用显示隐藏时展示动画效果实例

目录
  • 最终效果
  • 实现思路
  • 实现过程
  • 总结

最终效果

实现思路

窗口设置透明

建立系统托盘

获取托盘坐标,实现应用在托盘上方出现

CSS 里面写上加载和退出的动画

添加加载动画的事件,即给元素套上动画

设置单击事件,单击显示或者隐藏程序(或者添加 blur 事件,隐藏应用)

给托盘添加右键菜单退出应用

实现过程

窗口设置透明

const win = new BrowserWindow({
    width: 300,
    height: 400,
    frame: false, // 窗口边框
    skipTaskbar: true, // 窗口是否不显示在任务栏上面
    alwaysOnTop: true, // 窗口置顶
    transparent: true, // 窗口透明
    resizable: false,
    webPreferences: {
        // 通信文件 后面会用到
        preload: path.join(__dirname, "preload.js"),
        backgroundThrottling: false, // 后台运行是否禁止一些操作
    },
});

建立系统托盘

import { Tray } from "electron";

// 传入图标路径
tray = new Tray(path.join(__dirname, "../../public/imgs/logo.ico"));

// 鼠标悬浮托盘时显示的文字
tray.setToolTip("Todo");

获取托盘坐标,实现应用在托盘上方

// 获取托盘所在位置信息
const { width, height, x, y } = tray.getBounds();

// 获取窗口信息 win 是 BrowserWindow 对象
const [w, h] = win.getSize();

// 刚好在正上方
win.setPosition(x + width / 2 - w / 2, y - h - 10);

// 封装成函数
const aboveTrayPosition = (win, tray) => {
    const { width, height, x, y } = tray.getBounds();
    const [w, h] = win.getSize();
    return [x + width / 2 - w / 2, y - h - 10]
}

CSS 里面写上加载和退出的动画

动画应该添加到HTML根元素上,根元素必须得是 宽高 100%

@keyframes show {
    0% {
        opacity: 0;
        transform: translateY(300px) scale(0);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes hide {
    0% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
    100% {
        opacity: 0;
        transform: translateY(300px) scale(0);
    }
}

添加加载动画的事件

// preload.js
import { ipcRenderer } from "electron";

// 对应下面的 win.webContents.send("show");
// 默认有个 event 事件参数
ipcRenderer.on("show", (e) => {
    const root = document.querySelector(".root") as HTMLElement;
    root.style.animation = "show 0.3s linear forwards";
});

// 对应下面的 win.webContents.send("hide", s);
ipcRenderer.on("hide", (e, s: number) => {
    const root = document.querySelector(".root") as HTMLElement;
    root.style.animation = `hide ${s}s linear forwards`;
});

设置单击事件,单击显示或者隐藏程序并加载动画

// 添加托盘图标单击事件
tray.on("click", () => {
    // 窗口是否隐藏
    if (!win.isVisible()) {
        win.setPosition(...aboveTrayPosition(win, tray));
        win.show();

        // 展示加载动画
        win.webContents.send("show");
    } else {

        const s = 0.3;
        // 展示退出动画
        win.webContents.send("hide", s);

        // 退出动画加载完之后再隐藏程序
        setTimeout(() => {
            win.hide();
        }, s * 1000);
    }
});

给托盘添加右键菜单退出应用

import { Menu } from "electron";

// 创建菜单
let menu: Menu = Menu.buildFromTemplate([
    {
        label: "Quit",
        click() {
            app.quit();
        },
    },
]);

// 挂载到托盘右键上
tray.setContextMenu(menu);

总结

到此这篇关于Electron应用显示隐藏时展示动画的文章就介绍到这了,更多相关Electron显示隐藏展示动画内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Electron应用显示隐藏时展示动画效果实例

    目录 最终效果 实现思路 实现过程 总结 最终效果 实现思路 窗口设置透明 建立系统托盘 获取托盘坐标,实现应用在托盘上方出现 CSS 里面写上加载和退出的动画 添加加载动画的事件,即给元素套上动画 设置单击事件,单击显示或者隐藏程序(或者添加 blur 事件,隐藏应用) 给托盘添加右键菜单退出应用 实现过程 窗口设置透明 const win = new BrowserWindow({ width: 300, height: 400, frame: false, // 窗口边框 skipTask

  • jQuery实现常见的隐藏与展示列表效果示例

    本文实例讲述了jQuery实现常见的隐藏与展示列表效果.分享给大家供大家参考,具体如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <title>www.jb51.net jquery品牌

  • Vue中实现过渡动画效果实例详解

    目录 Vue的transition动画 Transition动画的使用 Transition组件的原理 Transition动画的class Vue的animation动画 Animation动画的使用 过渡的模式mode 列表过渡 列表过渡的介绍 列表过渡的使用 总结 Vue的transition动画 Transition动画的使用 在开发中,我们想要给一个组件的显示和消失添加某种过渡动画,可以很好的增加用户体验: React框架本身并没有提供任何动画相关的API,所以在React中使用过渡动

  • js定时器+简单的动画效果实例

    1.向下滑动 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>向下滑动</title> <style> body { margin: 0px; } #show { width: 200px; /* 高度为 0 */ height: 100px; background-color: lightc

  • jQuery模拟实现天猫购物车动画效果实例代码

    一.功能描述: 1.点击购买按钮,模拟抛物线将物品弹到购物车里: 2.购物车添加物品后,显示+1动画: 效果图如下: 实现如下: 1.导入jquery相关的包: <script type="text/javascript" src="jquery-2.1.1.min.js"></script> <script src="jquery.fly.min.js"></script> 2.html文件内容:

  • vue框架制作购物车小球动画效果实例代码

    最近在学习前端制作了一个购物车小球的动画效果 直接上图看看效果 下面介绍一下制作这个动画的详细过程: 1.因为使用vue锁业需要使用transition标签包裹 并指定动画三个动画生命周期函数 <transition @before-enter="beforeEnter" @enter="enter" @after-enter="afterEnter"> <div class="ball" v-if=&quo

  • 通过jquery实现页面的动画效果(实例代码)

    有很多函数可以用来实现动画效果,其中animate函数为最为常见的函数之一.以下为对该函数使用方式的简要介绍. animate函数基本形式 通过animate实现动画效果的基本形式为: $(selector).animate({params},speed,callback); 其中{params}为必须项,它是一个对象,指明了我们希望指定元素通过动画效果运行后,其所具有的的CSS样式,speed和callback则皆为可选项,其中speed指明了动画运行的速度,其值可为数值类型(如1000表示动

  • 微信小程序实现录音时的麦克风动画效果实例

    前言 这个简单的麦克风demo的创意是来源于"包你说"中的录音效果,实现的方式其实也并不难,但对于小程序中的简易动画的使用的确很实用. 效果 先来看个demo,gif帧数比较低,实际效果和真机测试的流畅性还是很OK的 思路 通过setTimeout配合this.sedData来改变image中的src路径来生成动画.动画的播放以及隐藏则通过wx:if绑定一个自定义的参数来控制.下面就直接上代码. 代码 html <view class='animation-talk'> &

  • javascript 通用loading动画效果实例代码

    由于项目中多处要给ajax提交的时候增加等待动画效果,所以就写了一个简单的通用js方法:代码如下: 复制代码 代码如下: /*ajax提交的延时等待效果*/ var AjaxLoding = new Object(); //wraperid : 显示loding图片的容器元素//ms:表示loding图标显示的时长,毫秒//envent:表示出发事件的事件源对象,用于获得出发事件的对象//callback:表示动画结束后执行的回掉方法//stop()方法表示在回掉方法执行成功后执行的隐藏动画的操

  • Android中ViewFlipper的使用及设置动画效果实例详解

    本文实例讲述了Android中ViewFlipper的使用及设置动画效果.分享给大家供大家参考,具体如下: 说到左右滑动,其实实现左右滑动的方式很多,有ViewPaer,自定义实现Viewgroup,gallery等都可以达到这种效果.这里做下ViewFliper实现左右滑动的效果. 会用到以下的技术: 1.ViewFlipper 2.GestureDetector 3.Animation 主要是这三个类在起作用. ViewFlipper,不妨把它看做一个容器吧,你可以把许多的View放在这个容

随机推荐