V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
这是一个专门讨论 idea 的地方。

每个人的时间,资源是有限的,有的时候你或许能够想到很多 idea,但是由于现实的限制,却并不是所有的 idea 都能够成为现实。

那这个时候,不妨可以把那些 idea 分享出来,启发别人。
meeop
V2EX  ›  奇思妙想

用 web 模拟桌面,感觉这个思路很有意思,但是想了想好像也没啥用

  •  
  •   meeop · 2024-07-10 11:08:02 +08:00 · 3896 次点击
    这是一个创建于 402 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如下链接复制到浏览器地址栏可以看看示例效果

    以前有一阵流行云桌面,现在都搜不到了,我在想以 pc 桌面的交互方式展示一般 web 服务,有啥有用的场景吗?

    data:text/html;base64,<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Desktop Simulation</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            background-color: #f0f0f0;
            margin: 0;
            overflow: auto;
            width: 100vw;
            height: 100vh;
        }

        #desktop {
            position: absolute;
            width: 1000%;
            height: 1000%;
            padding: 20px;
        }

        .shortcut {
            position: absolute;
            cursor: pointer;
            background-color: #fff;
            padding: 10px;
            border: 1px solid #ccc;
            border-radius: 5px;
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
        }

        .window {
            position: absolute;
            width: 50vw;

            height: 50vh;
            background-color: #fff;
            border: 1px solid #ccc;
            border-radius: 5px;
            box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
            z-index: 100;
        }

        .window-titlebar {
            background-color: #f0f0f0;
            padding: 8px;
            border-bottom: 1px solid #ccc;
            border-radius: 5px 5px 0 0;
            cursor: move;
        }

        .title {
            font-weight: bold;
        }

        .close-btn {
            float: right;
            border: none;
            background: none;
            cursor: pointer;
        }

        .window-content {
            padding: 10px;
            height: calc(100% - 30px);
            overflow: hidden;
        }

        .iframe-container {
            height: calc(100% - 30px);
        }

        .iframe-container iframe {
            width: 100%;
            height: 100%;
            border: none;
        }

        .resize-handle {
            position: absolute;
            width: 10px;
            height: 10px;
            bottom: 0;
            right: 0;
            cursor: nwse-resize;
            background-color: #ccc;
        }
    </style>
</head>

<body>
    <div id="desktop">
        <div class="shortcut" id="createWindowBtn" style="left: 200px; top: 30px;">
            点击创建浏览器窗口
        </div>
        <div>
            <button onclick='createBrowserWindow("https://ctool.dev/tool.html#/tool/json?category=conversion")'>jsonEdit</button><br>
        </div>
    </div>

    <script>
        let zIndex = 1; 

        
        document.getElementById('createWindowBtn').addEventListener('click', () => {
            createBrowserWindow();
        });

        
        function closeWindow(windowId) {
            document.getElementById(windowId).remove();
        }

        
        function dragWindow(windowId, event) {
            const windowElem = document.getElementById(windowId);
            windowElem.style.zIndex = ++zIndex; 
            let posX = event.clientX;
            let posY = event.clientY;
            let windowLeft = windowElem.offsetLeft;
            let windowTop = windowElem.offsetTop;

            function moveWindow(event) {
                let dx = event.clientX - posX;
                let dy = event.clientY - posY;
                windowElem.style.left = windowLeft + dx + 'px';
                windowElem.style.top = windowTop + dy + 'px';
            }

            function stopMove() {
                document.removeEventListener('mousemove', moveWindow);
                document.removeEventListener('mouseup', stopMove);
            }

            document.addEventListener('mousemove', moveWindow);
            document.addEventListener('mouseup', stopMove);
        }

        
        function createBrowserWindow(url) {
            const windowId = `window${zIndex}`;
            const iframeId = `iframe${zIndex}`;

            const newWindow = document.createElement('div');
            newWindow.id = windowId;
            newWindow.className = 'window';
            newWindow.style.left = '100px'; 
            newWindow.style.top = '100px'; 
            newWindow.style.zIndex = ++zIndex; 
            newWindow.innerHTML = `
            <div class="window-titlebar" onmousedown="dragWindow('${windowId}', event)">
                <span class="title">浏览器窗口</span>
                <button class="close-btn" onclick="closeWindow('${windowId}')">X</button>
            </div>
            <div class="window-content">
                <div class="iframe-container">
                    <iframe id="${iframeId}" src=""></iframe>
                </div>
            </div>
            <div class="resize-handle" onmousedown="startResize(event)"></div>
        `;
            document.body.appendChild(newWindow);

            
            const iframe = document.getElementById(iframeId);
            if (url) {
                iframe.src = url;
            } else {
                const inputUrl = prompt('请输入网址：', 'https://');
                if (inputUrl) {
                    iframe.src = inputUrl;
                }
            }

        }

        
        function startResize(event) {
            const resizeHandle = event.target;
            const windowElem = resizeHandle.parentElement;
            const iframeContainer = windowElem.querySelector('.iframe-container');
            const iframe = iframeContainer.querySelector('iframe');
            let startX = event.clientX;
            let startY = event.clientY;
            let startWidth = windowElem.offsetWidth;
            let startHeight = windowElem.offsetHeight;

            function resizeWindow(event) {
                let dx = event.clientX - startX;
                let dy = event.clientY - startY;
                let newWidth = startWidth + dx;
                let newHeight = startHeight + dy;

                
                windowElem.style.width = newWidth + 'px';
                windowElem.style.height = newHeight + 'px';
                iframeContainer.style.height = `calc(100% - ${windowElem.querySelector('.window-titlebar').offsetHeight}px)`;
            }

            function stopResize() {
                document.removeEventListener('mousemove', resizeWindow);
                document.removeEventListener('mouseup', stopResize);
            }

            document.addEventListener('mousemove', resizeWindow);
            document.addEventListener('mouseup', stopResize);
        }
    </script>
</body>

</html>

    22 条回复    2024-07-16 11:03:37 +08:00
    webbillion
        1
    webbillion  
       2024-07-10 11:54:38 +08:00
    没用但有意思,不是还有 jslinux 么
    leconio
        2
    leconio  
       2024-07-10 12:00:12 +08:00 via iPhone
    群晖主页
    nzd
        3
    nzd  
       2024-07-10 14:09:12 +08:00
    对 iPad 或许有用
    kero991
        4
    kero991  
       2024-07-10 14:50:14 +08:00   ❤️ 1
    前段时间不是有个很著名的开源项目是搞这个的吗
    https://puter.com/
    https://github.com/HeyPuter/puter

    另外,更早的可道云虽然是个文件管理项目,但也有个“云桌面”来着
    sentinelK
        5
    sentinelK  
       2024-07-10 14:57:53 +08:00   ❤️ 2
    窗口式交互在 2010 年左右火过一阵,但很快就烟消云散了。

    窗口式交互有几个前提:
    1 、需要有鼠标。
    2 、对设备带宽有比较大的需求。
    3 、屏幕需要够大。

    然后就是 2010 年左右,带宽逐渐满足了,ExtJS 等类似 UI 框架开始发力,然后 2012 年就移动互联网了……
    SkywalkerJi
        6
    SkywalkerJi  
       2024-07-10 15:02:55 +08:00
    被手机 app 干掉了,电脑都没人用了,模拟 pc 桌面还有什么意义。
    Configuration
        7
    Configuration  
       2024-07-10 15:28:26 +08:00   ❤️ 1
    @SkywalkerJi [电脑都没人用了] ,企业里的人都用手机办公的吗?
    cheneydog
        8
    cheneydog  
       2024-07-10 15:38:26 +08:00
    个人觉得适合集成各种管理软件。
    不同软件的界面风格肯定是不同的,直接拉到一个管理端,要么重新开发界面、要么乱起八糟。
    用桌面式方式集成,即使花花绿绿也不显得太乱。
    SawyerGuo
        9
    SawyerGuo  
       2024-07-10 16:09:37 +08:00
    我很早之前也有这想法,但是这类东西基本都没法运行常用 APP ,不如直接远程桌面。
    meeop
        10
    meeop  
    OP
       2024-07-10 17:02:20 +08:00
    @kero991 这个好强大
    Greendays
        11
    Greendays  
       2024-07-10 17:12:18 +08:00
    @kero991 牛的,给家里服务器装个看看
    royalknight
        12
    royalknight  
       2024-07-10 17:16:32 +08:00   ❤️ 1
    借楼推荐下我的 webos: https://github.com/royalknight56/vtron
    hades97
        13
    hades97  
       2024-07-11 09:29:17 +08:00   ❤️ 1
    有个叫 sealos 的,你可以看看
    guhuisec
        14
    guhuisec  
       2024-07-11 22:43:35 +08:00   ❤️ 1
    summerLast
        15
    summerLast  
       2024-07-12 09:58:59 +08:00   ❤️ 1
    LipGallagher
        16
    LipGallagher  
       2024-07-12 10:07:21 +08:00   ❤️ 1
    部署完了基本就没开过了 https://nav.sob.im/
    TaoQAQ
        17
    TaoQAQ  
       2024-07-12 10:47:01 +08:00
    有用,极空间就是配套的 Web 模拟桌面,用户操作起来有熟悉感。
    z1WhpL268TWE173O
        18
    z1WhpL268TWE173O  
       2024-07-13 07:45:53 +08:00
    有用的, 知道跨境行业的紫鸟浏览器吗? 大概率也是基于这个底层逻辑来实现的。
    Meteora626
        19
    Meteora626  
       2024-07-13 11:28:19 +08:00
    记得小学那时候 qq 空间好多这玩意,点进去就是一台电脑 可以用 qq 播放器啥的
    panda1001
        20
    panda1001  
       2024-07-14 08:42:22 +08:00 via Android
    十几年前火了一阵子,企鹅家做了个 Q+桌面。后来手机无窗口还不适应,装了个悬浮窗 app
    atpex
        21
    atpex  
       2024-07-15 16:39:08 +08:00
    @SkywalkerJi 想问题多点包容,不是什么东西都是一本道
    i706
        22
    i706  
       2024-07-16 11:03:37 +08:00
    早些时候模拟 win7 有用 熟悉操作
    关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2783 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 07:58 · PVG 15:58 · LAX 00:58 · JFK 03:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.