diff --git a/.gitea/workflows/build.yaml b/.gitea/workflows/build.yaml new file mode 100644 index 0000000..1966567 --- /dev/null +++ b/.gitea/workflows/build.yaml @@ -0,0 +1,47 @@ +name: Build +run-name: ${{ github.actor }} is upgrade release ๐Ÿš€ +on: [push] +env: + REPOSITORY: ${{ github.repository }} + COMMIT_ID: ${{ github.sha }} +jobs: + Build-Deploy-Actions: + runs-on: ubuntu-latest + steps: + - run: echo "๐ŸŽ‰ The job was automatically triggered by a ${{ github.event_name }} event." + - run: echo "๐Ÿง This job is now running on a ${{ runner.os }} server hosted by Gitea!" + - run: echo "๐Ÿ”Ž The name of your branch is ${{ github.ref }} and your repository is ${{ github.repository }}." + - name: Check out repository code + uses: actions/checkout@v3 + - + name: Setup Git LFS + run: | + git lfs install + git lfs fetch + git lfs checkout + - name: List files in the repository + run: | + ls ${{ github.workspace }} + - + name: Docker Image Info + id: image-info + run: | + echo "::set-output name=image_name::$(echo $REPOSITORY | tr '[:upper:]' '[:lower:]')" + echo "::set-output name=image_tag::${COMMIT_ID:0:10}" + - + name: Login to Docker Hub + uses: docker/login-action@v2 + with: + registry: artifacts.iflytek.com + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + - + name: Build and push + run: | + docker version + docker buildx build -t artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }} . --file ${{ github.workspace }}/Dockerfile --load + docker push artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }} + docker rmi artifacts.iflytek.com/docker-private/atp/${{ steps.image-info.outputs.image_name }}:${{ steps.image-info.outputs.image_tag }} + - run: echo "๐Ÿ This job's status is ${{ job.status }}." diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..f2167ff --- /dev/null +++ b/Dockerfile @@ -0,0 +1,11 @@ +FROM python:3.8.13 + +WORKDIR /app + +COPY . /app + +RUN pip config set global.index-url https://pypi.mirrors.ustc.edu.cn/simple +RUN apt-get update && apt-get install ffmpeg libsm6 libxext6 -y +RUN pip install -r requirements.txt + +CMD ["python", "app.py"] diff --git a/app.py b/app.py new file mode 100644 index 0000000..50481b8 --- /dev/null +++ b/app.py @@ -0,0 +1,51 @@ +from diffusers import StableDiffusionControlNetPipeline, ControlNetModel, UniPCMultistepScheduler +import torch +from controlnet_aux import OpenposeDetector +from diffusers.utils import load_image +from gradio.themes.utils import sizes +import gradio as gr + + +theme = gr.themes.Default(radius_size=sizes.radius_none).set( + block_label_text_color = '#4D63FF', + block_title_text_color = '#4D63FF', + button_primary_text_color = '#4D63FF', + button_primary_background_fill='#FFFFFF', + button_primary_border_color='#4D63FF', + button_primary_background_fill_hover='#EDEFFF', +) + +openpose = OpenposeDetector.from_pretrained('lllyasviel/ControlNet') +controlnet = ControlNetModel.from_pretrained( + "lllyasviel/sd-controlnet-openpose", torch_dtype=torch.float16 +) +pipe = StableDiffusionControlNetPipeline.from_pretrained( + "runwayml/stable-diffusion-v1-5", controlnet=controlnet, safety_checker=None, torch_dtype=torch.float16 +) + +def image2image(image, prompt): + image = openpose(image) + pipe.scheduler = UniPCMultistepScheduler.from_config(pipe.scheduler.config) + pipe.enable_xformers_memory_efficient_attention() + pipe.enable_model_cpu_offload() + image = pipe(prompt, image, num_inference_steps=20).images[0] + + return image + +with gr.Blocks(theme=theme, css="footer {visibility: hidden}") as demo: + gr.Markdown(""" +
ๆ นๆฎๅงฟๅŠฟ็”Ÿๆˆๅ›พ็‰‡
+ """) + with gr.Row(): + with gr.Column(): + image = gr.Image(label="ๅ›พ็‰‡", type='pil') + prompt = gr.Textbox(label="ๆ็คบ่ฏ") + with gr.Row(): + button = gr.Button("ๆไบค", variant="primary") + box2 = gr.Image(label="ๅ›พ็‰‡") + + button.click(fn=image2image, inputs=[image, prompt], outputs=box2) + examples = gr.Examples(examples=[['pose.png', 'chef in the kitchen']], inputs=[image, prompt], label="ไพ‹ๅญ") + +if __name__ == "__main__": + demo.queue(concurrency_count=3).launch(server_name = "0.0.0.0") diff --git a/pose.png b/pose.png new file mode 100644 index 0000000..e566939 Binary files /dev/null and b/pose.png differ diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 0000000..82028c5 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,7 @@ +controlnet_aux +xformers +diffusers +torch +gradio == 3.27.0 +transformers +accelerate