[开源初探]screenshot-to-code:将截图转化为代码

介绍说明

将截图转化为 HTML 代码的工具。该项目可以将屏幕截图转化为 HTML/JS/Tailwind CSS 代码,它使用 GPT-4 Vision 生成代码、DALL-E 3 生成相似的图片。

安装运行

为了方便演示及保持原有系统的简洁,将使用 docker 的方式来安装运行 screenshot-to-code。由于项目本身已经提供了 Dockerfile,我们直接使用即可,需要注意的是,该项目有 frontend 和 backend 两个镜像。

  • 克隆代码
复制代码
git clone https://github.com/abi/screenshot-to-code.git
  • 构建 frontend
复制代码
cd frontend/

docker build -t screenshot-to-code-frontend:latest -f ./Dockerfile .

docker images | grep screenshot-to-code-frontend
  • 构建 backend
复制代码
cd backend/

docker build -t screenshot-to-code-backend:latest -f ./Dockerfile .

docker images | grep screenshot-to-code-backend
  • 运行 frontend
复制代码
docker rm -f screenshot-to-code-frontend

docker run --name screenshot-to-code-frontend -d \
--network host \
-e VITE_WS_BACKEND_URL="ws://{your machine ip}:7001" \
screenshot-to-code-frontend:latest

docker ps | grep screenshot-to-code-frontend
  • 运行 backend
复制代码
docker rm -f screenshot-to-code-backend

docker run --name screenshot-to-code-backend -d \
--network host \
-e OPENAI_API_KEY="{your_openai_api_key}" \
screenshot-to-code-backend:latest \
poetry run uvicorn main:app --host 0.0.0.0 --port 7001

docker ps | grep screenshot-to-code-backend

使用简介

经过上述步骤后,screenshot-to-code 已成功运行,此时可通过服务器 IP + 5173 端口访问(需要设置相关安全组或防火墙规则,这里需要设置 5173 和 7001 两个端口)。

  • 主页
  • 手机助手截图
  • 生成过程
  • 查看源码
  • 生成页面
  • 源码
复制代码
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>网页示例</title>
    <script src="https://cdn.tailwindcss.com"></script>
    <style>
        body {
            font-family: 'PingFang SC', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
        }
</style>
</head>
<body class="bg-gray-100">
    <div class="flex h-screen">
        <!-- Sidebar -->
        <div class="w-1/5 bg-gray-800 text-white p-5">
            <div class="text-xl mb-8">导航栏目</div>
            <div class="text-lg mb-4">首页</div>
            <div class="text-lg mb-4">视频</div>
            <div class="text-lg mb-4">直播</div>
            <div class="text-lg mb-4">QQ空间</div>
            <div class="text-lg mb-4">微信公众</div>
            <div class="text-lg mb-4">手机天猫</div>
            <div class="text-lg mb-4">全球文化</div>
            <div class="text-lg mb-4">手机助手</div>
        </div>

        <!-- Main content -->
        <div class="w-4/5 p-5">
            <div class="flex justify-between border-b-2 border-gray-300 pb-2 mb-5">
                <div class="text-gray-700 text-lg">全部应用</div>
                <div class="space-x-2">
                    <button class="bg-blue-500 text-white px-4 py-2 rounded">全部应用</button>
                    <button class="bg-transparent text-blue-500 border border-blue-500 px-4 py-2 rounded">全部团队</button>
                    <button class="bg-transparent text-blue-500 border border-blue-500 px-4 py-2 rounded">下载新应用</button>
                </div>
            </div>
            <!-- Placeholder for content -->
            <div class="h-full"></div>
        </div>
    </div>
</body>
</html>

项目地址

更多项目详细信息请到项目主页获取

https://github.com/abi/screenshot-to-code

快捷镜像

ccr.ccs.tencentyun.com/erik_xu/screenshot-to-code-frontend:latest

ccr.ccs.tencentyun.com/erik_xu/screenshot-to-code-backend:latest

写在最后

开源初探\] 是一个介绍有趣开源项目的栏目,如果大家有什么问题或开源推荐,欢迎在文章或者公众号 - 跬步之巅留言交流。

相关推荐
xiangzhihong89 小时前
Figma 开源替代品 Penpot 安装与使用
开源·figma
板板正11 小时前
SpringAI——向量存储(vector store)
java·spring boot·ai
即兴小索奇11 小时前
【无标题】
人工智能·ai·商业·ai商业洞察·即兴小索奇
AlfredZhao13 小时前
手把手教你打造一个更懂你的AI翻译助手!
ai·agent·翻译·智能体·translation
TDengine (老段)13 小时前
TDengine IDMP 最佳实践
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
星域智链14 小时前
车载 GPS 与手机导航的终极对决:谁在复杂路况下更胜一筹?
大数据·科技·ai
雅菲奥朗17 小时前
雅菲奥朗SRE知识墙分享(一):『SRE对智能运维领域所产生的深远影响』
运维·ai·sre
即兴小索奇18 小时前
AI适老服务暖人心:AI适老机顶盒破数字鸿沟、毫米波雷达护独居安全,银发生活新保障
人工智能·ai·语音识别·商业·ai商业洞察·即兴小索奇
魔乐社区18 小时前
OpenAI重新开源!gpt-oss-20b适配昇腾并上线魔乐社区
人工智能·gpt·深度学习·开源·大模型
智能物联实验室18 小时前
如何低门槛自制Zigbee 3.0温湿度计?涂鸦上新开发包,开箱即用、完全开源
嵌入式硬件·开源·硬件工程