From 299ce010bd8f2f5a65e4fa5a033a122b318b8c83 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C5=99emysl=20Janouch?= Date: Fri, 11 Feb 2011 18:37:00 +0100 Subject: Update the symbol library. * Add bipolar, IGFET and JFET transistors. * Add more variants to some symbols. * Add a symbol for a simple terminal. * Avoid unneccessary stroke() calls. * Fix comments. --- share/library/Active/bipolar.lua | 73 +++++++++++++++++++++++++++ share/library/Active/category.json | 5 ++ share/library/Active/icon.svg | 53 ++++++++++++++++++++ share/library/Active/igfet.lua | 73 +++++++++++++++++++++++++++ share/library/Active/jfet.lua | 63 ++++++++++++++++++++++++ share/library/Logical/and.lua | 8 ++- share/library/Logical/not.lua | 8 ++- share/library/Logical/or.lua | 7 ++- share/library/Misc/ground.lua | 2 +- share/library/Misc/lamp.lua | 7 +-- share/library/Misc/power-source.lua | 4 +- share/library/Misc/switch.lua | 8 +-- share/library/Misc/terminal.lua | 29 +++++++++++ share/library/Passive/capacitor.lua | 34 ++++++++++--- share/library/Passive/diode.lua | 98 ++++++++++++++++++++++++++++++++----- share/library/Passive/inductor.lua | 14 +++--- share/library/Passive/resistor.lua | 76 +++++++++++++++++++++++++--- 17 files changed, 507 insertions(+), 55 deletions(-) create mode 100644 share/library/Active/bipolar.lua create mode 100644 share/library/Active/category.json create mode 100644 share/library/Active/icon.svg create mode 100644 share/library/Active/igfet.lua create mode 100644 share/library/Active/jfet.lua create mode 100644 share/library/Misc/terminal.lua diff --git a/share/library/Active/bipolar.lua b/share/library/Active/bipolar.lua new file mode 100644 index 0000000..f08983f --- /dev/null +++ b/share/library/Active/bipolar.lua @@ -0,0 +1,73 @@ +-- Symbol names +local names_npn = +{ + en = "NPN transistor", + cs = "Tranzistor NPN" +} + +local names_pnp = +{ + en = "PNP transistor", + cs = "Tranzistor PNP" +} + +-- Render area in base units (X1, Y1, X2, Y2) +local area = {-2, -2, 2, 2} + +-- Terminal points +local terminals = {{-2, 0}, {2, 2}, {2, -2}} + +-- Rendering +local render = function (cr) + -- The terminals + cr.move_to (-2, 0) + cr.line_to (0, 0) + + cr.move_to (0, 0.5) + cr.line_to (2, 2) + + cr.move_to (0, -0.5) + cr.line_to (2, -2) + + -- The ohmic connection + cr.move_to (0, -1) + cr.line_to (0, 1) + + cr.stroke () +end + +local render_npn = function (cr) + render (cr) + + cr.save () + cr.translate (0, -0.5) + cr.rotate (math.atan2 (-2, -1.5)) + + cr.move_to (-0.4, 0.8) + cr.line_to (0, 1.4) + cr.line_to (0.4, 0.8) + + cr.stroke () + cr.restore () +end + +local render_pnp = function (cr) + render (cr) + + cr.save () + cr.translate (2, -2) + cr.rotate (math.atan2 (2, 1.5)) + + cr.move_to (-0.4, 1.3) + cr.line_to (0, 1.9) + cr.line_to (0.4, 1.3) + + cr.stroke () + cr.restore () +end + +-- Register the symbols +logdiag.register ("NPN", names_npn, area, terminals, render_npn) +logdiag.register ("PNP", names_pnp, area, terminals, render_pnp) + + diff --git a/share/library/Active/category.json b/share/library/Active/category.json new file mode 100644 index 0000000..1f8cd4a --- /dev/null +++ b/share/library/Active/category.json @@ -0,0 +1,5 @@ +{ + "en": "Active", + "cs": "Aktivní" +} + diff --git a/share/library/Active/icon.svg b/share/library/Active/icon.svg new file mode 100644 index 0000000..66f74ec --- /dev/null +++ b/share/library/Active/icon.svg @@ -0,0 +1,53 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/share/library/Active/igfet.lua b/share/library/Active/igfet.lua new file mode 100644 index 0000000..4479269 --- /dev/null +++ b/share/library/Active/igfet.lua @@ -0,0 +1,73 @@ +-- Symbol names +local names_igfet_n = +{ + en = "N-channel IGFET transistor", + cs = "Tranzistor IGFET s kanálem N" +} + +local names_igfet_p = +{ + en = "P-channel IGFET transistor", + cs = "Tranzistor IGFET s kanálem P" +} + +-- Render area in base units (X1, Y1, X2, Y2) +local area = {-2, -1.5, 2, 1.5} + +-- Terminal points +local terminals = {{-2, 1}, {2, 1}, {2, 0}, {2, -1}} + +-- Rendering +local render = function (cr) + -- The terminals + cr.move_to (-2, 1) + cr.line_to (-0.3, 1) + cr.line_to (-0.3, -1) + + cr.move_to (0, 1) + cr.line_to (2, 1) + + cr.move_to (0, 0) + cr.line_to (2, 0) + + cr.move_to (0, -1) + cr.line_to (2, -1) + + -- Source, gate, drain + cr.move_to (0, -1.5) + cr.line_to (0, -0.5) + + cr.move_to (0, -0.3) + cr.line_to (0, 0.3) + + cr.move_to (0, 0.5) + cr.line_to (0, 1.5) + + cr.stroke () +end + +local render_igfet_n = function (cr) + render (cr) + + cr.move_to (0.9, -0.4) + cr.line_to (0.4, 0) + cr.line_to (0.9, 0.4) + + cr.stroke () +end + +local render_igfet_p = function (cr) + render (cr) + + cr.move_to (0.4, -0.4) + cr.line_to (0.9, 0) + cr.line_to (0.4, 0.4) + + cr.stroke () +end + +-- Register the symbols +logdiag.register ("IGFET-N", names_igfet_n, area, terminals, render_igfet_n) +logdiag.register ("IGFET-P", names_igfet_p, area, terminals, render_igfet_p) + + diff --git a/share/library/Active/jfet.lua b/share/library/Active/jfet.lua new file mode 100644 index 0000000..30c0eb9 --- /dev/null +++ b/share/library/Active/jfet.lua @@ -0,0 +1,63 @@ +-- Symbol names +local names_jfet_n = +{ + en = "N-channel JFET transistor", + cs = "Tranzistor JFET s kanálem N" +} + +local names_jfet_p = +{ + en = "P-channel JFET transistor", + cs = "Tranzistor JFET s kanálem P" +} + +-- Render area in base units (X1, Y1, X2, Y2) +local area = {-2, -1.5, 2, 1.5} + +-- Terminal points +local terminals = {{-2, 1}, {2, 1}, {2, -1}} + +-- Rendering +local render = function (cr) + -- The terminals + cr.move_to (-2, 1) + cr.line_to (0, 1) + + cr.move_to (0, 1) + cr.line_to (2, 1) + + cr.move_to (0, -1) + cr.line_to (2, -1) + + -- The ohmic connection + cr.move_to (0, -1.5) + cr.line_to (0, 1.5) + + cr.stroke () +end + +local render_jfet_n = function (cr) + render (cr) + + cr.move_to (-1, 0.6) + cr.line_to (-0.5, 1) + cr.line_to (-1, 1.4) + + cr.stroke () +end + +local render_jfet_p = function (cr) + render (cr) + + cr.move_to (-0.4, 0.6) + cr.line_to (-1, 1) + cr.line_to (-0.4, 1.4) + + cr.stroke () +end + +-- Register the symbols +logdiag.register ("JFET-N", names_jfet_n, area, terminals, render_jfet_n) +logdiag.register ("JFET-P", names_jfet_p, area, terminals, render_jfet_p) + + diff --git a/share/library/Logical/and.lua b/share/library/Logical/and.lua index c169075..4da8aad 100644 --- a/share/library/Logical/and.lua +++ b/share/library/Logical/and.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-4, -2, 5, 2} --- Terminals +-- Terminal points local terminals = {{-4, -1}, {-4, 1}, {5, 0}} -- Rendering @@ -19,19 +19,17 @@ local render = function (cr) cr.arc (1, 0, 2, math.pi * 1.5, math.pi * 0.5) cr.line_to (-2, 2) cr.close_path () - cr.stroke () - -- The contacts + -- The terminals cr.move_to (-4, -1) cr.line_to (-2, -1) - cr.stroke () cr.move_to (-4, 1) cr.line_to (-2, 1) - cr.stroke () cr.move_to (3, 0) cr.line_to (5, 0) + cr.stroke () end diff --git a/share/library/Logical/not.lua b/share/library/Logical/not.lua index e37880e..89d2a2a 100644 --- a/share/library/Logical/not.lua +++ b/share/library/Logical/not.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-4, -2, 4, 2} --- Terminals +-- Terminal points local terminals = {{-4, 0}, {4, 0}} -- Rendering @@ -18,20 +18,18 @@ local render = function (cr) cr.line_to (2, 0) cr.line_to (-2, 2) cr.close_path () - cr.stroke () -- The circle cr.new_sub_path () cr.arc (2.25, 0, 0.25, 0, 2 * math.pi) - cr.stroke () - -- The contacts + -- The terminals cr.move_to (-4, 0) cr.line_to (-2, 0) - cr.stroke () cr.move_to (2.5, 0) cr.line_to (4, 0) + cr.stroke () end diff --git a/share/library/Logical/or.lua b/share/library/Logical/or.lua index 49ccd6c..96d4f76 100644 --- a/share/library/Logical/or.lua +++ b/share/library/Logical/or.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-4, -2, 5, 2} --- Terminals +-- Terminal points local terminals = {{-4, -1}, {-4, 1}, {5, 0}} -- Rendering @@ -22,7 +22,7 @@ local render = function (cr) cr.curve_to (-1, 1, -1, -1, -2, -2) cr.stroke () - -- The contacts + -- The terminals cr.save () -- Crop the contacts according to @@ -36,12 +36,11 @@ local render = function (cr) cr.move_to (-4, -1) cr.line_to (-1, -1) - cr.stroke () cr.move_to (-4, 1) cr.line_to (-1, 1) - cr.stroke () + cr.stroke () cr.restore () cr.move_to (3, 0) diff --git a/share/library/Misc/ground.lua b/share/library/Misc/ground.lua index 0c36240..0cd352a 100644 --- a/share/library/Misc/ground.lua +++ b/share/library/Misc/ground.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-1, -1, 1, 2} --- Terminals +-- Terminal points local terminals = {{0, -1}} -- Rendering diff --git a/share/library/Misc/lamp.lua b/share/library/Misc/lamp.lua index 9ecf9ea..e80683f 100644 --- a/share/library/Misc/lamp.lua +++ b/share/library/Misc/lamp.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-2, -1, 2, 1} --- Terminals +-- Terminal points local terminals = {{-2, 0}, {2, 0}} -- Rendering @@ -25,16 +25,17 @@ local render = function (cr) cr.move_to (1, -1) cr.line_to (-1, 1) - cr.stroke () + cr.stroke () cr.restore () - -- The contacts + -- The terminals cr.move_to (-2, 0) cr.line_to (-1, 0) cr.move_to (1, 0) cr.line_to (2, 0) + cr.stroke () end diff --git a/share/library/Misc/power-source.lua b/share/library/Misc/power-source.lua index 00a8498..c79b0ac 100644 --- a/share/library/Misc/power-source.lua +++ b/share/library/Misc/power-source.lua @@ -8,7 +8,7 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-1, -2, 1, 2} --- Terminals +-- Terminal points local terminals = {{-1, 0}, {1, 0}} -- Rendering @@ -20,7 +20,7 @@ local render = function (cr) cr.move_to (0.2, -2) cr.line_to (0.2, 2) - -- The contacts + -- The terminals cr.move_to (-1, 0) cr.line_to (-0.2, 0) diff --git a/share/library/Misc/switch.lua b/share/library/Misc/switch.lua index c4d031e..06ca771 100644 --- a/share/library/Misc/switch.lua +++ b/share/library/Misc/switch.lua @@ -8,16 +8,16 @@ local names = -- Render area in base units (X1, Y1, X2, Y2) local area = {-2, -1.5, 2, 0} --- Terminals +-- Terminal points local terminals = {{-2, 0}, {2, 0}} -- Rendering -local render_normal = function (cr) +local render = function (cr) -- The switch contact cr.move_to (1.3, -1.3) cr.line_to (-1, 0) - -- The contacts + -- The terminals cr.move_to (-2, 0) cr.line_to (-1, 0) @@ -28,6 +28,6 @@ local render_normal = function (cr) end -- Register the symbol -logdiag.register ("Switch", names, area, terminals, render_normal) +logdiag.register ("Switch", names, area, terminals, render) diff --git a/share/library/Misc/terminal.lua b/share/library/Misc/terminal.lua new file mode 100644 index 0000000..fe21f83 --- /dev/null +++ b/share/library/Misc/terminal.lua @@ -0,0 +1,29 @@ +-- Symbol name +local names = +{ + en = "Terminal", + cs = "Terminál" +} + +-- Render area in base units (X1, Y1, X2, Y2) +local area = {-1, -0.5, 0.5, 0.5} + +-- Terminal points +local terminals = {{-1, 0}} + +-- Rendering +local render = function (cr) + -- The circle + cr.arc (0, 0, 0.3, 0, math.pi * 2) + + -- The contact + cr.move_to (-1, 0) + cr.line_to (-0.3, 0) + + cr.stroke () +end + +-- Register the symbol +logdiag.register ("Terminal", names, area, terminals, render) + + diff --git a/share/library/Passive/capacitor.lua b/share/library/Passive/capacitor.lua index c6abc28..02cf0ce 100644 --- a/share/library/Passive/capacitor.lua +++ b/share/library/Passive/capacitor.lua @@ -5,10 +5,17 @@ local names = cs = "Kondenzátor" } +local names_polar = +{ + en = "Polarized capacitor", + cs = "Polarizovaný kondenzátor" +} + -- Render area in base units (X1, Y1, X2, Y2) -local area = {-2, -1, 2, 1} +local area = {-2, -1, 2, 1} +local area_polar = {-2, -1.5, 2, 1} --- Terminals +-- Terminal points local terminals = {{-2, 0}, {2, 0}} -- Rendering @@ -16,23 +23,36 @@ local render = function (cr) -- The vertical lines cr.move_to (-0.2, -1) cr.line_to (-0.2, 1) - cr.stroke () cr.move_to (0.2, -1) cr.line_to (0.2, 1) - cr.stroke () - -- The contacts + -- The terminals cr.move_to (-2, 0) cr.line_to (-0.2, 0) - cr.stroke () cr.move_to (0.2, 0) cr.line_to (2, 0) + + cr.stroke () +end + +local render_polar = function (cr) + render (cr) + + cr.move_to (0.6, -1) + cr.line_to (1.4, -1) + + cr.move_to (1, -1.4) + cr.line_to (1, -0.6) + cr.stroke () end -- Register the symbol -logdiag.register ("Capacitor", names, area, terminals, render) +logdiag.register ("Capacitor", + names, area, terminals, render) +logdiag.register ("CapacitorPolarized", + names_polar, area_polar, terminals, render_polar) diff --git a/share/library/Passive/diode.lua b/share/library/Passive/diode.lua index 06e9b16..4d155f7 100644 --- a/share/library/Passive/diode.lua +++ b/share/library/Passive/diode.lua @@ -1,41 +1,117 @@ --- Symbol name +-- Symbol names local names = { en = "Diode", cs = "Dioda" } +local names_zener = +{ + en = "Zener diode", + cs = "Zenerova dioda" +} + +local names_led = +{ + en = "Light-emitting diode", + cs = "Svítivá dioda" +} + +local names_photo = +{ + en = "Photodiode", + cs = "Fotodioda" +} + -- Render area in base units (X1, Y1, X2, Y2) -local area = {-2, -1, 2, 1} +local area = {-2, -1, 2, 1} +local area_rad = {-2, -2.5, 2, 1} --- Terminals +-- Terminal points local terminals = {{-2, 0}, {2, 0}} -- Rendering -local render_normal = function (cr) +local render = function (cr) -- The triangle cr.move_to (-1, -1) cr.line_to (1, 0) cr.line_to (-1, 1) cr.line_to (-1, -1) - cr.stroke () -- The vertical line cr.move_to (1, 1) cr.line_to (1, -1) - cr.stroke () - -- The contacts + -- The terminals cr.move_to (-2, 0) - cr.line_to (-1, 0) + cr.line_to (2, 0) + cr.stroke () +end + +local render_zener = function (cr) + render (cr) + + cr.move_to (1, 1) + cr.line_to (0.5, 1) - cr.move_to (1, 0) - cr.line_to (2, 0) cr.stroke () end +local render_arrow = function (cr) + cr.move_to (0, 0) + cr.line_to (0, -1.5) + + cr.stroke () + + cr.move_to (-0.3, -0.7) + cr.line_to (0, -1.5) + cr.line_to (0.3, -0.7) + cr.close_path () + + cr.fill () +end + +local render_radiation = function (cr) + cr.save () + cr.translate (-0.4, 0) + render_arrow (cr) + cr.restore () + + cr.save () + cr.translate (0.4, 0) + render_arrow (cr) + cr.restore () +end + +local render_led = function (cr) + render (cr) + + cr.save () + cr.translate (-0.3, -1.0) + cr.rotate (math.atan2 (1, 1)) + + render_radiation (cr) + + cr.restore () +end + +local render_photo = function (cr) + render (cr) + + cr.save () + cr.translate (0.75, -2.05) + cr.rotate (math.atan2 (-1, -1)) + + render_radiation (cr) + + cr.restore () +end + -- Register the symbol -logdiag.register ("Diode", names, area, terminals, render) +logdiag.register ("Diode", names, area, terminals, render) +logdiag.register ("DiodeZener", names_zener, area, terminals, render_zener) +logdiag.register ("DiodeLED", names_led, area_rad, terminals, render_led) +logdiag.register ("DiodePhoto", names_photo, area_rad, terminals, render_photo) diff --git a/share/library/Passive/inductor.lua b/share/library/Passive/inductor.lua index b94f357..b7b64dd 100644 --- a/share/library/Passive/inductor.lua +++ b/share/library/Passive/inductor.lua @@ -1,5 +1,5 @@ -- Symbol names -local names_normal = +local names = { en = "Inductor", cs = "Cívka" @@ -14,30 +14,32 @@ local names_core = -- Render area in base units (X1, Y1, X2, Y2) local area = {-2, -1, 2, 0} --- Terminals +-- Terminal points local terminals = {{-2, 0}, {2, 0}} -- Rendering -local render_normal = function (cr) +local render = function (cr) -- The arcs cr.arc (-1.5, 0, 0.5, math.pi, 0) cr.arc (-0.5, 0, 0.5, math.pi, 0) cr.arc (0.5, 0, 0.5, math.pi, 0) cr.arc (1.5, 0, 0.5, math.pi, 0) + cr.stroke () end local render_core = function (cr) - render_normal (cr) + render (cr) -- The core cr.move_to (-2, -1) cr.line_to (2, -1) + cr.stroke () end -- Register the symbols -logdiag.register ("Inductor", names_normal, area, terminals, render_normal) -logdiag.register ("InductorWithCore", names_core, area, terminals, render_core) +logdiag.register ("Inductor", names, area, terminals, render) +logdiag.register ("InductorWithCore", names_core, area, terminals, render_core) diff --git a/share/library/Passive/resistor.lua b/share/library/Passive/resistor.lua index 262969b..f59f20e 100644 --- a/share/library/Passive/resistor.lua +++ b/share/library/Passive/resistor.lua @@ -5,11 +5,26 @@ local names = cs = "Rezistor" } +local names_adj = +{ + en = "Adjustable resistor", + cs = "Nastavitelný rezistor" +} + +local names_pot = +{ + en = "Potentiometer", + cs = "Potenciometr" +} + -- Render area in base units (X1, Y1, X2, Y2) -local area = {-2, -0.5, 2, 0.5} +local area = {-2, -0.5, 2, 0.5} +local area_adj = {-2, -1.5, 2, 1} +local area_pot = {-2, -2, 2, 0.5} --- Terminals -local terminals = {{-2, 0}, {2, 0}} +-- Terminal points +local terminals = {{-2, 0}, {2, 0}} +local terminals_pot = {{-2, 0}, {2, 0}, {2, -2}} -- Rendering local render = function (cr) @@ -19,19 +34,66 @@ local render = function (cr) cr.line_to (1.5, 0.5) cr.line_to (-1.5, 0.5) cr.line_to (-1.5, -0.5) - cr.stroke () - -- The contacts + -- The terminals cr.move_to (-2, 0) cr.line_to (-1.5, 0) - cr.stroke () cr.move_to (1.5, 0) cr.line_to (2, 0) + cr.stroke () end +local render_adj = function (cr) + render (cr) + + -- The arrow + cr.move_to (-1, 1) + cr.line_to (1, -1) + + cr.stroke () + + cr.save () + cr.translate (1.5, -1.5) + cr.rotate (math.atan2 (1, 1)) + + cr.move_to (0, 0) + cr.line_to (0.3, 0.8) + cr.line_to (-0.3, 0.8) + cr.close_path () + + cr.fill () + cr.restore () +end + +local render_pot = function (cr) + render (cr) + + -- The contact + cr.move_to (0, -2) + cr.line_to (2, -2) + + -- The arrow + cr.move_to (0, -2) + cr.line_to (0, -1) + + cr.stroke () + + cr.move_to (0, -0.5) + cr.line_to (0.3, -1.3) + cr.line_to (-0.3, -1.3) + cr.close_path () + + cr.fill () +end + -- Register the symbol -logdiag.register ("Resistor", names, area, terminals, render) +logdiag.register ("Resistor", + names, area, terminals, render) +logdiag.register ("ResistorAdjustable", + names_adj, area_adj, terminals, render_adj) +logdiag.register ("Potentiometer", + names_pot, area_pot, terminals_pot, render_pot) -- cgit v1.2.3