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

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

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

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

  •  
  •   meeop · 165 天前 · 3351 次点击
    这是一个创建于 165 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    以前有一阵流行云桌面,现在都搜不到了,我在想以 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  
       165 天前
    没用但有意思,不是还有 jslinux 么
    leconio
        2
    leconio  
       165 天前 via iPhone
    群晖主页
    nzd
        3
    nzd  
       165 天前
    对 iPad 或许有用
    kero991
        4
    kero991  
       165 天前   ❤️ 1
    前段时间不是有个很著名的开源项目是搞这个的吗
    https://puter.com/
    https://github.com/HeyPuter/puter

    另外,更早的可道云虽然是个文件管理项目,但也有个“云桌面”来着
    sentinelK
        5
    sentinelK  
       165 天前   ❤️ 2
    窗口式交互在 2010 年左右火过一阵,但很快就烟消云散了。

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

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