Metadata-Version: 2.4
Name: cool-qrcode
Version: 0.1.3
Summary: A Python library for generating personalized QR codes
Home-page: https://github.com/xxk59/cool-qrcode
Author: Kelvin Xu
Author-email: Kelvin Xu <xxk59@hotmail.com>
License-Expression: MIT
Project-URL: Homepage, https://github.com/xxk59/cool-qrcode
Project-URL: Repository, https://github.com/xxk59/cool-qrcode
Project-URL: Issues, https://github.com/xxk59/cool-qrcode/issues
Keywords: qrcode,qr,barcode,generator,personalized
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Multimedia :: Graphics
Classifier: Topic :: Utilities
Requires-Python: >=3.7
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: qrcode[pil]>=7.4.2
Requires-Dist: Pillow>=8.0.0
Requires-Dist: numpy>=1.21.0
Provides-Extra: dev
Requires-Dist: pytest>=6.0; extra == "dev"
Requires-Dist: pytest-cov; extra == "dev"
Requires-Dist: black; extra == "dev"
Requires-Dist: flake8; extra == "dev"
Requires-Dist: mypy; extra == "dev"
Dynamic: author
Dynamic: home-page
Dynamic: license-file
Dynamic: requires-python

# Cool QRCode

一个用于生成个性化二维码的 Python 库，支持自定义颜色、形状、Logo 和蒙板效果。

![示例二维码](docs/images/all_features.png)

## 特性

- 🎨 **自定义颜色** - 支持命名颜色和十六进制颜色代码
- ⭐ **预设风格** - 内置 8 种精美配色方案
- 🔘 **自定义形状** - 支持方形和圆形码点
- 🖼️ **添加 Logo** - 支持方形和圆形 Logo
- 🎭 **蒙板效果** - 添加半透明色彩蒙板
- 💫 **万能 API** - 通过单一函数支持所有效果组合
- 🚸 **学生友好** - 提供简单易用的中文 API 和教程

## 安装

```bash
pip install cool-qrcode
```

## 快速开始

### 基本使用

```python
from cool_qrcode import make_cool_qrcode

# 最简单的用法
make_cool_qrcode("Hello, World!", filename="basic.png")
```

### 使用预设风格

```python
# 使用海洋风格
make_cool_qrcode(
    "Hello, Ocean!",
    style="ocean",
    filename="ocean_style.png"
)
```

![海洋风格](docs/images/ocean_style.png)

### 圆形码点

```python
# 使用圆形码点
make_cool_qrcode(
    "Hello, Circle!",
    dot_shape="circle",
    fill_color="green",
    back_color="white",
    filename="circle_dots.png"
)
```

![圆形码点](docs/images/circle_dots.png)

### 添加 Logo

```python
# 添加圆形Logo
make_cool_qrcode(
    "Hello, Logo!",
    logo_path="your_logo.png",
    logo_circular=True,
    filename="with_logo.png"
)
```

![带Logo](docs/images/circular_logo.png)

### 组合所有效果

```python
# 组合多种效果
make_cool_qrcode(
    "Hello, Cool QRCode!",
    style="berry",        # 使用预设风格
    dot_shape="circle",   # 圆形码点
    logo_path="logo.png", # 添加Logo
    logo_circular=True,   # 圆形Logo
    mask_color="purple",  # 紫色蒙板
    mask_opacity=0.15,    # 透明度
    size=600,             # 大尺寸
    filename="cool_qr.png"
)
```

## 文档

### make_cool_qrcode() 万能 API

```python
make_cool_qrcode(
    data,                  # 二维码内容
    filename=None,         # 保存文件名
    size=500,              # 图片大小
    fill_color="black",    # 前景色
    back_color="white",    # 背景色
    style=None,            # 预设风格
    dot_shape="square",    # 码点形状
    logo_path=None,        # Logo路径
    logo_circular=True,    # Logo是否为圆形
    mask_color=None,       # 蒙板颜色
    mask_opacity=0.3       # 蒙板透明度
)
```

详细使用方法参见 [API 文档](https://github.com/xxk59/cool-qrcode/blob/main/docs/API.md)。

## 支持的颜色

支持多种命名颜色和十六进制颜色代码，包括：

- 基础颜色：red, green, blue, yellow, purple, orange...
- 常用颜色：aqua, fuchsia, lime, maroon, navy, olive...
- 扩展颜色：lightblue, darkgreen, lavender...

详细颜色列表参见 [颜色参考](https://github.com/xxk59/cool-qrcode/blob/main/colors-reference.md)。

## 预设风格

内置 8 种精美配色方案：

- ocean - 海洋风格（蓝色系）
- forest - 森林风格（绿色系）
- sunset - 日落风格（橙色系）
- berry - 浆果风格（紫色系）
- fire - 火焰风格（红色系）
- mint - 薄荷风格（青色系）
- chocolate - 巧克力风格（棕色系）
- night - 夜空风格（深蓝系）

## 示例

详细示例代码见 [examples](https://github.com/xxk59/cool-qrcode/tree/main/examples) 目录。

## 许可证

本项目采用 MIT 许可证 - 详见 [LICENSE](https://github.com/xxk59/cool-qrcode/blob/main/LICENSE) 文件
