{{<admonitiontype=warningtitle="Work in progress"open=true>}}
Estos apuntes son personales y no valen para aprender a usar KiCAD, mejor búscate un buen tutorial en la red
{{</admonition>}}
## Notas sueltas de KiCAD 6
### Schematic Editor
- Nueva opción para buscar y sustituir símbolos: _Edit->Change Symbols_ o botón derecho del ratón sobre el símbolo a cambiar. Hay que mirar las opciones con atención para hacer los cambios deseados.
- Se puede seleccionar por rectángulos añadiendo "pedacitos" manteniendo pulsada la tecla de mayúsculas y quitando "pedacitos" sin soltar la mayúscula y pulsando Control.
## Import dxf file as _Edge Cut_
### Pasos básicos
Estas notas están basadas en la importación del silk para la Badge de la OSHwdem
1) Abri el PDF desde Inkscape
2) Me pasé un buen rato limpiándolo
3) Hice unas cuantas operaciones para dejar la silueta como un solo
'Path' en Inkscape
4) Me hice un fichero solo con la silueta y lo salve como DXF, puede
haber más caminos, pero yo siempre uso DXF (LibreCAD) para diseñar los
contornos de las placas). Use "Autocad DXF R14" en la
opción 'Save as'
5) Importe el DXF en KiCAD, asegurándome de importarlo en la capa Edge
Cut (que es el contorno físico de la PCB)
Pruebas con KiCAD 7
**Desde LibreCAD**
- LibreCAD con un círculo simple: OK
- LibreCAD con un círculo simple (R14): No conserva bien el tamaño (sale muy grande)
- LibreCAD complejo con una sola capa: OK
- LibreCAD complejo capa visible exportada a svg: OK
Partimos de un fichero svg que gestionamos con Inkscape.
- El fichero tiene que ser en blanco y negro. Desde KiCAD vamos a
poder gestionar el fichero y su negativo
- No puede tener canal alfa, hay que añadir un fondo, blanco o negro.
- Tenemos que exportar el fichero a png, al menos con 1200 dpi
- Para no liarnos es mejor dimensionar el fichero en Inkscape al tamaño
que queramos en la placa
- Lo que vemos negro en la pantalla del Bitmap será entintado en el silk
- Si vemos el logo muy pequeño en la pantalla del _Bitmap Converter_ es
señal de que hay que aumentar los dpi en el export de Inkscape.
## Usar Bibliotecas de terceros (por ejemplo las de Bricolabs)
Tendremos dos maneras de usar las Bibliotecas
* Globalmente en nuestro sistema
* Como submodulos de nuestro proyecto
### Globalmente
Esta es la forma más simple de tener las bibliotecas disponibles para todos nuestros proyectos y también facilita poder contribuir con nuevos componentes a esas bibliotecas. Pero si queremos distribuir nuestro proyecto no será tan elegante.
Clonamos el [repo de las bibliotecas](https://gitlab.com/brico-labs/bricolabs_kicad_library) en algún directorio de nuestro ordenador (p.ej. `~/Resources/KiCAD/`)
En el propio _KiCAD_ añadimos las bibliotecas como bibliotecas globales: desde la ventana principal de KiCAD menu `Preferences::Manage Symbol Libraries`, para los símbolos de esquema, y `Preferences::Manage Footprint Libraries` para las huellas.
Alternativamente si queremos añadir las bibliotecas de forma que solo afecten al proyecto en el que estamos trabajando podemos añadirlas en la pestaña de Proyecto en lugar de en la global.
### Como submodulos git de nuestro proyecto
Aquí presuponemos que usas git para el control de versiones de tu proyecto KiCAD.
Las bibliotecas se añaden como submodulos git en el directorio del proyecto y se añaden después mediante las preferencias de KiCAD como dijimos en el punto anterior.
Las ventajas de hacerlo así son que facilita la distribución del proyecto y que se fija la versión de las bibliotecas que estamos usando.
## Crear un nuevo símbolo de componente para nuestros esquemas
No es muy conveniente cambiar el contenido de bibliotecas que se han añadido como submodulos git a nuestro proyecto. Salvo que controles bien el git te vas a meter en problemas. Mejor añadir las bibliotecas desde un directorio independiente y entonces las puedes editar sin problemas (aunque las propias bibliotecas las controles con git)
{{</admonition>}}
## De Inkscape a KiCAD (extensión shenzhen)
Aparentemente la extensión [shenzhen](https://github.com/badgeek/svg2shenzhen) no funciona para Inkscape 1.1
Podemos hacerla funcionar:
* Descargamos la [AppImage para Inkscape 1.0.2](https://inkscape.org/release/all/gnulinux/appimage/). Yo la dejo en mi directorio `~/apps/inkscape`
* Creamos un enlace simbólico a la *AppImage* más reciente (esto es para facilitar los cambios de versión)
```bash
cd ~/apps/inkscape
ln -s <appImage> current
```
* Creamos un script `shenzhen` con el siguiente contenido
```bash
#!/usr/bin/env bash
export HOME=/home/salvari/apps/inkscape
~/current
```
* Una vez ejecutado el script para comprobar que se abre correctamente el Inkscape, bajamos el fichero de la extensión desde el [github](https://github.com/badgeek/svg2shenzhen#install) y lo descomprimimos en el directorio `~/apps/inkscape/.config/inkscape/extensions`
* Si rearrancamos nuestro Inkscape 1.0.2 con el script `shenzhen` veremos que ya tenemos la extensión funcionando.
Vamos a usar [estos scripts](https://github.com/lachlanA/eagle-to-kicad)
## Notas sueltas
* Para **copiar un símbolo entre bibliotecas**: Abrir el _Symbol Editor_ navegar hasta el símbolo a copiar y con el
botón derecho seleccionar _Salvar Copia como.._ Y seleccionamos en que
librería se quiere salvar.
* Para poner un **texto negado** (con una raya por arriba) se rodea el texto con tildes `~negado~`
* Para **copiar entre esquemas de distintos proyectos**. Hay que usar la aplicación _eeschema_ independiente para abrir los esquemas, no se puede copiar entre proyectos
## Huella mixta (tht smd)
Copiamos la THT desde la biblio de KiCAD
## KiCAD 6, módulos Python para Pcbnew
Podemos acceder a la consola (intérprete) de Python desde _pcbnew_.
```python
Py 0.9.8
Python 3.8.10 (default, Jun 22 2022, 20:18:18)
[GCC 9.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.