File size: 1,894 Bytes
c03bb65
ef12d1e
1ec76d9
c03bb65
 
ef12d1e
c03bb65
ef12d1e
 
 
 
 
c03bb65
ef12d1e
c03bb65
ef12d1e
 
 
 
 
 
 
c03bb65
 
 
 
1ec76d9
ef12d1e
5b3af7e
1ec76d9
ef12d1e
c03bb65
1ec76d9
ef12d1e
 
 
 
1ec76d9
c03bb65
 
 
 
ef12d1e
 
 
c03bb65
05811a6
1ec76d9
ef12d1e
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import streamlit as st
from diffusers import StableDiffusionPipeline
import torch

@st.cache_resource
def load_lightweight_pipeline():
    device = "cuda" if torch.cuda.is_available() else "cpu"
    pipeline = StableDiffusionPipeline.from_pretrained(
        "CompVis/stable-diffusion-v1-4", 
        torch_dtype=torch.float16 if device == "cuda" else torch.float32
    ).to(device)
    return pipeline

def generate_image(pipeline, prompt, negative_prompt):
    try:
        image = pipeline(
            prompt=prompt,
            negative_prompt=negative_prompt,
            num_inference_steps=25,
            guidance_scale=7.5
        ).images[0]
        return image
    except Exception as e:
        st.error(f"Error generating image: {str(e)}")
        return None

st.title("Image Generator")
st.markdown('<small>By Taizun</small>', unsafe_allow_html=True)

prompt = st.text_input("Enter your prompt")
pipeline = load_lightweight_pipeline()

styles_dict = {
    "Neon Vibes": {"prompt": "neon lights in a futuristic city", "negative_prompt": "blurred, dull"},
    "Retro Sci-Fi": {"prompt": "retro futuristic landscape", "negative_prompt": "realistic, modern"},
    "Mystic Forest": {"prompt": "dark mystical forest with glowing lights", "negative_prompt": "sunny, bright"},
    "Abstract Art": {"prompt": "abstract colorful shapes", "negative_prompt": "realistic, detailed"}
}

style_name = st.selectbox("Select a Style", options=list(styles_dict.keys()))

if style_name:
    selected_style = styles_dict[style_name]
    style_prompt = selected_style["prompt"]
    negative_prompt = selected_style["negative_prompt"]

if st.button("Generate Image"):
    with st.spinner("Generating your image..."):
        image = generate_image(pipeline, prompt + " " + style_prompt, negative_prompt)
        if image:
            st.image(image, caption="Generated Image", use_column_width=True)