
Finished switch to JSONRPC commit 9cf6dd9a0e03c71135c01d4ad4f7d3be0f1e3066 Author: Giovanni Harting <giovanni.harting@touchdata.net> Date: Sat Oct 10 21:09:20 2015 +0200 fixed some bugs added some missing things from transition commit 8ed44b8fcde739b541b1834049025b055a50e6fe Author: Marius Schiffer <marius@mschiffer.de> Date: Sat Oct 10 05:53:41 2015 +0200 Creating fresh database works now. Fixed pwm_freq property. commit dc88ef0df427f90746a499912eff70dfce967c55 Author: Marius Schiffer <marius@mschiffer.de> Date: Sat Oct 10 04:40:41 2015 +0200 Completed SQLAlchemy integration. Completed JSON-RPC integration. All daemon class functionality is now on module-level (required for JSON-RPC decorators). Migrations will have to be reimplemented with alembic. commit a4cabdcd00a3e2a3cbbd92a3c9d59a4235e4d277 Author: Marius Schiffer <marius@mschiffer.de> Date: Sat Oct 10 03:00:19 2015 +0200 First steps towards SQLAlchemy integration.
70 lines
2.2 KiB
Python
70 lines
2.2 KiB
Python
# LEDD Project
|
|
# Copyright (C) 2015 LEDD Team
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from spectra import Color
|
|
from sqlalchemy import Integer, ForeignKey, String, Float, Boolean
|
|
from sqlalchemy import Column
|
|
|
|
from . import Base
|
|
|
|
|
|
class Stripe(Base):
|
|
__tablename__ = "stripe"
|
|
"""
|
|
A stripe is the smallest controllable unit.
|
|
"""
|
|
id = Column(Integer, primary_key=True)
|
|
controller_id = Column(Integer, ForeignKey('controller.id'))
|
|
name = Column(String)
|
|
channel_r = Column(Integer)
|
|
channel_g = Column(Integer)
|
|
channel_b = Column(Integer)
|
|
channel_r_gamma = Column(Float, default=2.8)
|
|
channel_g_gamma = Column(Float, default=2.8)
|
|
channel_b_gamma = Column(Float, default=2.8)
|
|
rgb = Column(Boolean)
|
|
|
|
@property
|
|
def channels(self):
|
|
return self.channel_r, self.channel_b, self.channel_g
|
|
|
|
# TODO save channels to db
|
|
|
|
@channels.setter
|
|
def channels(self, t):
|
|
self.channel_r, self.channel_g, self.channel_b = t
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
|
|
def read_color(self):
|
|
rc = tuple([float(self.controller.get_channel(channel)) for channel in self.channels])
|
|
c = Color("rgb", rc[0], rc[1], rc[2])
|
|
self._color = c.to("hsv")
|
|
|
|
def __repr__(self):
|
|
return "<Stripe id={}>".format(self.id)
|
|
|
|
def set_color(self, c):
|
|
self._color = c
|
|
for channel, gamma_correct, value in zip(self.channels, self.gamma_correct, c.clamped_rgb):
|
|
self.controller.set_channel(channel, value, gamma_correct)
|
|
|
|
def get_color(self):
|
|
return self._color
|
|
|
|
color = property(get_color, set_color)
|