Zur Beschreibungsseite auf Commons

Datei:7segment multiplexing.gif

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen

Originaldatei(1.688 × 630 Pixel, Dateigröße: 518 KB, MIME-Typ: image/gif, Endlosschleife, 61 Bilder, 12 s)

Diese Datei und die Informationen unter dem roten Trennstrich werden aus dem zentralen Medienarchiv Wikimedia Commons eingebunden.

Zur Beschreibungsseite auf Commons


Beschreibung

Beschreibung
Deutsch: Multiplexing einer 7-Segment-Anzeige.
Anzeige von "1.234" in verschiedenen Frequenzen.
Datum
Quelle Eigenes Werk
Urheber Laserlicht

Python code

#Path to Cairo Lib
import os
os.environ["PATH"] = r"D:\Programme\msys64\mingw64\bin" + os.pathsep + os.environ["PATH"]

import numpy as np
import drawSvg as draw

############################

#load and ransform segments
#based on Coords from here: https://commons.wikimedia.org/wiki/File:7_Segment_Display_with_Labeled_Segments.svg
seg = [ # X, Y
        [[278.759,242.759,98.759,62.759,98.759,242.759,278.759,242.759], [520.74,556.74,556.74,520.74,484.74,484.74,520.74,556.74]], #A
        [[287.759,323.759,323.759,287.759,251.759,251.759,287.759,323.759], [295.928,331.928,475.928,511.928,475.928,331.928,295.928,331.928]], #B
        [[287.759,323.759,323.759,287.759,251.759,251.759,287.759,323.759], [64.427,100.427,244.427,280.427,244.427,100.427,64.427,100.427]], #C
        [[278.759,242.759,98.759,62.759,98.759,242.759,278.759,242.759], [55.26,91.26,91.26,55.26,19.26,19.26,55.26,91.26]], #D
        [[53.758,89.759,89.759,53.758,17.758,17.758,53.758,89.759], [64.427,100.427,244.427,280.427,244.427,100.427,64.427,100.427]], #E
        [[53.758,89.758,89.758,53.758,17.758,17.758,53.758,89.758], [295.928,331.928,475.928,511.928,475.928,331.928,295.928,331.928]], #F
        [[278.759,242.759,98.759,62.759,98.759,242.759,278.759,242.759], [287.927,323.928,323.928,287.927,251.927,251.927,287.927,323.928]] #G
      ]
seg = np.array(seg)
circle = np.array([373.241, 515.74])

offs = np.array([17.758, 19.26])

circle -= offs

offs = np.repeat(offs[:, np.newaxis], 8, axis=1)
offs = np.repeat(offs[np.newaxis, :, :], 7, axis=0)

seg -= offs

scale_f = 537.48
seg /= scale_f
circle /= scale_f
circle = np.absolute(circle + np.array([0, -1]))
circle_r = 41 / scale_f

############################

seg_decoder = {
    "0": [False, True, True, True, True, True, True],
    "1": [False, False, False, False, True, True, False],
    "2": [True, False, True, True, False, True, True],
    "3": [True, False, False, True, True, True, True],
    "4": [True, True, False, False, True, True, False],
    "5": [True, True, False, True, True, False, True],
    "6": [True, True, True, True, True, False, True],
    "7": [False, False, False, False, True, True, True],
    "8": [True, True, True, True, True, True, True],
    "9": [True, True, False, True, True, True, True],
    "A": [True, True, True, False, True, True, True],
    "B": [True, True, True, True, True, False, False],
    "C": [False, True, True, True, False, False, True],
    "D": [True, False, True, True, True, True, False],
    "E": [True, True, True, True, False, False, True],
    "F": [True, True, True, False, False, False, True],
    " ": [False, False, False, False, False, False, False],
    '█': [True, True, True, True, True, True, True]
}

############################

def render(text, point, column_switch, seg_switch_draw):
    d = draw.Drawing(402, 150, origin=(0, 0), displayInline=False)
    d.append(draw.Rectangle(0, 0, 585, 150, fill='#ffffff'))

    for i in range(len(text)):
        char = text[i]

        seg1 = seg * 100

        offs = np.array([90 * i + 4 + 50, 5])
        offs = np.repeat(offs[:, np.newaxis], 8, axis=1)
        offs = np.repeat(offs[np.newaxis, :, :], 7, axis=0)
        seg1 += offs

        color_enabled = 'green'
        color_disabled = '#eeeeee'
        color_wire_disabled = 'gray'
        color_wire_enabled_p = 'red'
        color_wire_enabled_m = 'blue'

        d.append(draw.Rectangle(90 * i + 50, 0, 82, 110-0.25, fill='#cccccc', stroke='black', stroke_width=0.5))
        d.append(draw.Lines(*np.ravel(seg1[0],'F'), close=False, fill=color_enabled if seg_decoder[char][6] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[1],'F'), close=False, fill=color_enabled if seg_decoder[char][5] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[2],'F'), close=False, fill=color_enabled if seg_decoder[char][4] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[3],'F'), close=False, fill=color_enabled if seg_decoder[char][3] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[4],'F'), close=False, fill=color_enabled if seg_decoder[char][2] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[5],'F'), close=False, fill=color_enabled if seg_decoder[char][1] else color_disabled, stroke='black'))
        d.append(draw.Lines(*np.ravel(seg1[6],'F'), close=False, fill=color_enabled if seg_decoder[char][0] else color_disabled, stroke='black'))
        d.append(draw.Circle(*(circle * 100 + np.array([90 * i + 4 + 50, 5])), circle_r * 100, fill=color_enabled if point[i] else color_disabled, stroke_width=1, stroke='black'))

        d.append(draw.Text(str(i + 1), 9, 90 * i + 50 + 41 - 2, 143, fill='magenta'))
        d.append(draw.Line(90 * i + 50 + 41, 110, 90 * i + 50 + 41, 120, stroke=color_wire_enabled_m if column_switch[i] else color_wire_disabled, stroke_width=2, fill='none'))
        d.append(draw.Line(90 * i + 50 + 41, 130, 90 * i + 50 + 41, 140, stroke=color_wire_enabled_m, stroke_width=2, fill='none'))
        a = 2 if not column_switch[i] else 0
        d.append(draw.Line(90 * i + 50 + 41 - 2 - a, 118, 90 * i + 50 + 41 - 2 - a, 132, stroke=color_wire_enabled_m if column_switch[i] else color_wire_disabled, stroke_width=2, fill='none'))

        for j in range(8):
            en = (seg_decoder[text[seg_switch_draw]] + [point[seg_switch_draw]])[j]
            d.append(draw.Line(90 * i + 50, 110 / 9 * (j + 1), 90 * i + 50 - 8, 110 / 9 * (j + 1), stroke=color_wire_enabled_p if en else color_wire_disabled, stroke_width=2, fill='none'))

            if i==seg_switch_draw:
                d.append(draw.Text(["DP", "A", "B", "C", "D", "E", "F", "G"][::-1][j], 9, 7, 110 / 9 * (j + 1) - 3, fill='magenta'))
                d.append(draw.Line(50 - 20, 110 / 9 * (j + 1), 50 - 10 - 20, 110 / 9 * (j + 1), stroke='red', stroke_width=2, fill='none'))
                b = 2 if not en else 0
                d.append(draw.Line(50 - 6, 110 / 9 * (j + 1) + 2 + b, 50 - 10 - 12, 110 / 9 * (j + 1) + 2 + b, stroke='red', stroke_width=2, fill='none'))
                
    d.setPixelScale(4.2)  # Set number of pixels per geometry unit
    #d.setRenderSize(400,200)  # Alternative to setPixelScale
    #d.saveSvg('example.svg')
    #d.savePng('example.png')

    #d.rasterize()  # Display as PNG
    #d  # Display as SVG
    return d

############################

from apng import APNG
import os, numpy, PIL
from PIL import Image

files = []
f = 0

text = "1234"
pointpos = 0

for j in range(6):
  delay = 1000/2**j

  for _ in range(j):
    for i in range(len(text)):
      fn = "R:/Temp/" + str(f).zfill(5) + ".png"

      seg_switch_draw = i
      column_switch = [i==x for x in range(len(text))]
      point = [i==pointpos==x for x in range(len(text))]
      text_masked = "".join([x if i==index else " " for index, x in enumerate(text)])

      render(text_masked, point, column_switch, seg_switch_draw).savePng(fn)
      
       #remove colors
      arr = numpy.array(Image.open(fn),dtype=numpy.float)
      arr = numpy.array(numpy.round(arr),dtype=numpy.uint8)
      arr = numpy.bitwise_and(arr >> 4, 0x0f)
      arr = numpy.bitwise_and(arr << 4, 0xff)
      out = Image.fromarray(arr,mode="RGB")
      out.save(fn)

      files.append((fn, delay))

      f += 1

#mean
file, delay = files[0]
w,h = Image.open(file).size
N = len(text)
arr = numpy.zeros((h,w,3),numpy.float)
for i in range(len(text)):
  file, delay = files[-i]
  imarr = numpy.array(Image.open(file),dtype=numpy.float)
  arr = arr+imarr/N
arr = numpy.array(numpy.round(arr),dtype=numpy.uint8)

arr = numpy.bitwise_and(arr >> 4, 0x0f) #remove colors
arr = numpy.bitwise_and(arr << 4, 0xff)

out = Image.fromarray(arr,mode="RGB")
out.save(r"R:\Temp\avg.png")
files.append((r"R:\Temp\avg.png", 5000))

im = APNG()
for file, delay in files:
  im.append_file(file, delay=int(delay))
im.save(r"R:\Temp\result.png")

from IPython.display import Image
Image(filename=r"R:\Temp\result.png")

#apng2gif result.png result.gif



Lizenz

Image:

w:de:Creative Commons
Namensnennung Weitergabe unter gleichen Bedingungen
Namensnennung: Laserlicht
Dieses Werk darf von dir
  • verbreitet werden – vervielfältigt, verbreitet und öffentlich zugänglich gemacht werden
  • neu zusammengestellt werden – abgewandelt und bearbeitet werden
Zu den folgenden Bedingungen:
  • Namensnennung – Du musst angemessene Urheber- und Rechteangaben machen, einen Link zur Lizenz beifügen und angeben, ob Änderungen vorgenommen wurden. Diese Angaben dürfen in jeder angemessenen Art und Weise gemacht werden, allerdings nicht so, dass der Eindruck entsteht, der Lizenzgeber unterstütze gerade dich oder deine Nutzung besonders.
  • Weitergabe unter gleichen Bedingungen – Wenn du das Material wiedermischst, transformierst oder darauf aufbaust, musst du deine Beiträge unter der gleichen oder einer kompatiblen Lizenz wie das Original verbreiten.

Source:

Diese Datei ist lizenziert unter der Expat-Lizenz, auch als MIT-Lizenz bekannt:

Urheberrecht © Laserlicht

Hiermit wird jeder Person, die eine Kopie dieser Software und der dazugehörigen Dokumentationsdateien (die „Software“) erhalten hat, unentgeltlich die Erlaubnis erteilt, diese Software uneingeschränkt zu benutzen, einschließlich ohne Einschränkung der Rechte auf Nutzung, Kopien, Änderung, Zusammenführung, Veröffentlichung, Vertrieb, Unterlizenzierung und/oder Verkauf von Kopien der Software, und Personen, die diese Software erhalten, diese Rechte gemäß folgenden Bedingungen zu erteilen:

Der obige Urheberechtshinweis und dieser Erlaubnisvermerk sind in allen Kopien oder wesentlichen Teilen der Software beizulegen.

Die Software wird so wie sie ist ohne ausdrückliche oder inbegriffene Garantie bereitgestellt, einschließlich der nicht nur darauf beschränkten Garantien für die Gebrauchstauglichkeit, der Nutzung für einen bestimmten Zweck sowie jeglicher Rechtsverletzung. Keinesfalls sind die Autoren oder Urheberrechtsinhaber für jegliche Forderungen, Schäden oder andere Ansprüche haftbar zu machen, weder durch Erfüllung eines Vertrages, eines Vergehens oder andere Ereignisse in Verbindung mit der Software oder sonstiger Verwendung der Software.


An den Hochladenden: Die MIT-Lizenz hat verschiedene Versionen, du solltest die Lizenz präziser angeben. Klicke für Details auf {{MIT}}.

Kurzbeschreibungen

Ergänze eine einzeilige Erklärung, was diese Datei darstellt.

In dieser Datei abgebildete Objekte

Motiv

image/gif

0aafdf6bfcf739840261d4eb0d1c285e12a319d4

530.074 Byte

12 Sekunde

630 Pixel

1.688 Pixel

Dateiversionen

Klicke auf einen Zeitpunkt, um diese Version zu laden.

Version vomVorschaubildMaßeBenutzerKommentar
aktuell23:58, 25. Feb. 2022Vorschaubild der Version vom 23:58, 25. Feb. 20221.688 × 630 (518 KB)Laserlichthighest speed not possible in browser...
23:54, 25. Feb. 2022Vorschaubild der Version vom 23:54, 25. Feb. 20221.688 × 630 (708 KB)LaserlichtThumb->Animation
23:40, 25. Feb. 2022Vorschaubild der Version vom 23:40, 25. Feb. 20222.010 × 750 (850 KB)LaserlichtUploaded own work with UploadWizard

Die folgenden 2 Seiten verwenden diese Datei:

Globale Dateiverwendung

Die nachfolgenden anderen Wikis verwenden diese Datei: