Convert Figma logo to code with AI

SawyerHood logodraw-a-ui

Draw a mockup and generate html for it

13,331
1,605
13,331
50

Top Related Projects

Keras model to generate HTML code from hand-drawn website mockups. Implements an image captioning architecture to drawn source images.

11,981

pix2code: Generating Code from a Graphical User Interface Screenshot

7,528

A tool for defining design systems and using them to generate cross-platform UI code, Sketch files, and other artifacts.

A neural network that transforms a design mock-up into a static website.

Quick Overview

Draw a UI is an innovative project that allows users to generate web application user interfaces from simple drawings. It utilizes artificial intelligence to interpret hand-drawn sketches and convert them into functional HTML and CSS code. This tool bridges the gap between design ideation and implementation, potentially revolutionizing the UI/UX design process.

Pros

  • Rapid prototyping: Quickly transform ideas into functional UI designs
  • Intuitive interface: Simple drawing-based input makes it accessible to non-developers
  • AI-powered: Leverages advanced machine learning for accurate interpretation of sketches
  • Time-saving: Reduces the time needed to create initial UI mockups

Cons

  • Limited customization: Generated code may not always match exact design intentions
  • Dependency on AI accuracy: Results can vary based on the quality of the input sketch
  • Learning curve: Users may need to adapt their drawing style for optimal results
  • Potential over-reliance: May discourage learning fundamental web development skills

Code Examples

// Example 1: Initializing the Draw a UI component
import { DrawUI } from 'draw-a-ui';

const drawUI = new DrawUI({
  canvas: document.getElementById('drawing-canvas'),
  outputElement: document.getElementById('code-output')
});
// Example 2: Generating UI code from a sketch
drawUI.generateCode().then(code => {
  console.log('Generated HTML:', code.html);
  console.log('Generated CSS:', code.css);
});
// Example 3: Customizing the output style
drawUI.setStylePreferences({
  colorScheme: 'dark',
  fontFamily: 'Arial, sans-serif',
  borderRadius: '5px'
});

Getting Started

To get started with Draw a UI, follow these steps:

  1. Install the package:

    npm install draw-a-ui
    
  2. Import and initialize the component in your project:

    import { DrawUI } from 'draw-a-ui';
    
    const drawUI = new DrawUI({
      canvas: document.getElementById('drawing-canvas'),
      outputElement: document.getElementById('code-output')
    });
    
  3. Set up event listeners for user interactions:

    document.getElementById('generate-btn').addEventListener('click', () => {
      drawUI.generateCode().then(code => {
        // Handle the generated code
      });
    });
    
  4. Customize the output as needed using the available API methods.

Competitor Comparisons

Keras model to generate HTML code from hand-drawn website mockups. Implements an image captioning architecture to drawn source images.

Pros of sketch-code

  • Supports multiple output formats (HTML/CSS, Android XML, iOS Swift)
  • Includes a dataset of hand-drawn wireframes for training
  • Offers a more comprehensive pipeline for wireframe-to-code conversion

Cons of sketch-code

  • Less recent updates and potentially outdated dependencies
  • Requires more setup and preprocessing of input images
  • May have lower accuracy on complex UI designs

Code Comparison

draw-a-ui:

const response = await fetch("https://api.openai.com/v1/chat/completions", {
  method: "POST",
  headers: {
    "Content-Type": "application/json",
    Authorization: `Bearer ${apiKey}`,
  },
  body: JSON.stringify({
    model: "gpt-4-vision-preview",
    messages: [
      {
        role: "user",
        content: [
          { type: "text", text: prompt },
          {
            type: "image_url",
            image_url: {
              url: `data:image/png;base64,${base64Image}`,
            },
          },
        ],
      },
    ],
    max_tokens: 4096,
  }),
});

sketch-code:

def get_model(input_shape):
    # CNN encoder
    encoder_input = Input(shape=input_shape, name="encoder_input")
    encoder_output = Conv2D(64, kernel_size=(3, 3), activation='relu', padding='same', strides=(2, 2))(encoder_input)
    encoder_output = Conv2D(128, kernel_size=(3, 3), activation='relu', padding='same')(encoder_output)
    encoder_output = Conv2D(256, kernel_size=(3, 3), activation='relu', padding='same')(encoder_output)
11,981

pix2code: Generating Code from a Graphical User Interface Screenshot

Pros of pix2code

  • Supports multiple output formats (HTML/CSS, Android XML, iOS Storyboard)
  • Includes a comprehensive dataset for training and evaluation
  • Offers a more complete end-to-end solution for UI generation

Cons of pix2code

  • Less recent and potentially outdated compared to newer approaches
  • Requires more complex setup and dependencies
  • Limited to specific UI patterns and may struggle with modern design trends

Code Comparison

draw-a-ui:

const response = await fetch("https://api.openai.com/v1/chat/completions", {
  method: "POST",
  headers: {
    "Content-Type": "application/json",
    Authorization: `Bearer ${apiKey}`,
  },
  body: JSON.stringify({
    model: "gpt-4-vision-preview",
    messages: [
      {
        role: "user",
        content: [
          {
            type: "text",
            text: `Generate HTML and Tailwind CSS for the UI in this image. ${prompt}`,
          },
          {
            type: "image_url",
            image_url: {
              url: `data:image/png;base64,${base64Image}`,
            },
          },
        ],
      },
    ],
    max_tokens: 4096,
  }),
});

pix2code:

def run(input_path, output_path, model_json_file, model_weights_file, vocab_path, search_method):
    np.random.seed(0)
    
    model = load_model(model_json_file, model_weights_file)
    
    vocab = Vocabulary()
    vocab.retrieve(vocab_path)
    
    compiler = Compiler(vocab)
    
    png_path = input_path
    
    img_features = get_img_features(png_path)
    
    generated_gui, sequences = generate_gui(model, img_features, vocab, search_method)
7,528

A tool for defining design systems and using them to generate cross-platform UI code, Sketch files, and other artifacts.

Pros of Lona

  • Comprehensive design system tool with a focus on cross-platform consistency
  • Supports design tokens and component libraries for scalable design systems
  • Offers a visual editor for creating and managing design components

Cons of Lona

  • Steeper learning curve due to its more complex feature set
  • May be overkill for smaller projects or quick prototyping tasks
  • Requires more setup and configuration compared to simpler tools

Code Comparison

Draw-a-ui:

const prompt = `A sign up form with email and password fields`;
const ui = await generateUI(prompt);

Lona:

let emailField = TextInput(placeholder: "Email")
let passwordField = SecureInput(placeholder: "Password")
let signUpForm = Form([emailField, passwordField])

Draw-a-ui focuses on generating UI from natural language prompts, while Lona provides a more structured approach to defining UI components programmatically. Draw-a-ui is better suited for rapid prototyping and exploring ideas, whereas Lona is designed for building and maintaining comprehensive design systems across multiple platforms.

A neural network that transforms a design mock-up into a static website.

Pros of Screenshot-to-code

  • Generates code from existing UI designs, allowing for faster prototyping of existing concepts
  • Supports multiple output formats (HTML/CSS, React, Vue)
  • Includes a more comprehensive dataset for training

Cons of Screenshot-to-code

  • Requires pre-existing UI designs or screenshots as input
  • May struggle with complex or non-standard UI elements
  • Less flexible for iterative design processes

Code Comparison

Screenshot-to-code (HTML output):

<div class="container">
  <h1>Welcome</h1>
  <p>This is a sample page.</p>
  <button class="btn">Click me</button>
</div>

Draw-a-ui (React output):

<div className="flex flex-col items-center justify-center h-screen bg-gray-100">
  <h1 className="text-4xl font-bold mb-4">Welcome</h1>
  <p className="text-lg mb-6">This is a sample page.</p>
  <button className="bg-blue-500 text-white px-4 py-2 rounded">Click me</button>
</div>

Both repositories aim to streamline the UI development process, but they approach the task differently. Screenshot-to-code focuses on translating existing designs into code, while Draw-a-ui generates UI components from text descriptions. The choice between the two depends on the specific needs of the project and the preferred workflow of the development team.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

draw-a-ui

This is an app that uses tldraw and the gpt-4-vision api to generate html based on a wireframe you draw.

I'm currently working on a hosted version of draw-a-ui. You can join the waitlist at draw-a-ui.com. The core of it will always be open source and available here.

A demo of the app

This works by just taking the current canvas SVG, converting it to a PNG, and sending that png to gpt-4-vision with instructions to return a single html file with tailwind.

Disclaimer: This is a demo and is not intended for production use. It doesn't have any auth so you will go broke if you deploy it.

Getting Started

This is a Next.js app. To get started run the following commands in the root directory of the project. You will need an OpenAI API key with access to the GPT-4 Vision API.

Note this uses Next.js 14 and requires a version of node greater than 18.17. Read more here.

echo "OPENAI_API_KEY=sk-your-key" > .env.local
npm install
npm run dev

Open http://localhost:3000 with your browser to see the result.