Relax type bounds
This commit is contained in:
parent
b9369247bf
commit
128e645a20
5 changed files with 16 additions and 14 deletions
|
@ -14,7 +14,7 @@
|
|||
// limitations under the License.
|
||||
|
||||
/// A color channel
|
||||
pub trait Channel: Num + ToChannel{
|
||||
pub trait Channel: Num + ToChannel {
|
||||
/// Convert a channel to the enclosing type
|
||||
///
|
||||
/// # Example
|
||||
|
|
|
@ -15,7 +15,8 @@
|
|||
|
||||
use std::num;
|
||||
|
||||
use color::{Channel, FloatChannel};
|
||||
use color::{Channel, ToChannel};
|
||||
use color::{FloatChannel, ToFloatChannel};
|
||||
use color::{RGB, ToRGB};
|
||||
|
||||
#[path = "../num_macros.rs"]
|
||||
|
@ -34,7 +35,7 @@ pub trait ToHSV {
|
|||
pub fn to_hsv<U:Clone + FloatChannel>(&self) -> HSV<U>;
|
||||
}
|
||||
|
||||
impl<T:Clone + FloatChannel> ToHSV for HSV<T> {
|
||||
impl<T:Clone + ToFloatChannel> ToHSV for HSV<T> {
|
||||
#[inline]
|
||||
pub fn to_hsv<U:Clone + FloatChannel>(&self) -> HSV<U> {
|
||||
HSV::new(FloatChannel::from((*self).h.clone()),
|
||||
|
@ -43,7 +44,7 @@ impl<T:Clone + FloatChannel> ToHSV for HSV<T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<T:Clone + FloatChannel> ToRGB for HSV<T> {
|
||||
impl<T:Clone + Float + ToChannel> ToRGB for HSV<T> {
|
||||
pub fn to_rgb<U:Clone + Channel>(&self) -> RGB<U> {
|
||||
// Algorithm taken from the Wikipedia article on HSL and HSV:
|
||||
// http://en.wikipedia.org/wiki/HSL_and_HSV#From_HSV
|
||||
|
|
|
@ -15,7 +15,8 @@
|
|||
|
||||
use std::cast;
|
||||
|
||||
use color::{Channel, FloatChannel};
|
||||
use color::{Channel, ToChannel};
|
||||
use color::{FloatChannel, ToFloatChannel};
|
||||
use color::{HSV, ToHSV, RGB, ToRGB, RGBA, ToRGBA};
|
||||
|
||||
#[path = "../num_macros.rs"]
|
||||
|
@ -35,20 +36,20 @@ pub trait ToHSVA {
|
|||
pub fn to_hsva<U:Clone + FloatChannel>(&self) -> HSVA<U>;
|
||||
}
|
||||
|
||||
impl<C: ToHSV, T:Clone + FloatChannel> ToHSVA for (C, T) {
|
||||
impl<C: ToHSV, T:Clone + ToFloatChannel> ToHSVA for (C, T) {
|
||||
#[inline]
|
||||
pub fn to_hsva<U:Clone + FloatChannel>(&self) -> HSVA<U> {
|
||||
match *self {
|
||||
(ref c, ref a) => unsafe {
|
||||
cast::transmute::<(HSV<U>, U), HSVA<U>>(
|
||||
(c.to_hsv::<U>(), Channel::from(a.clone()))
|
||||
(c.to_hsv::<U>(), FloatChannel::from(a.clone()))
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<T:Clone + FloatChannel> ToRGBA for HSVA<T> {
|
||||
impl<T:Clone + Float + ToChannel> ToRGBA for HSVA<T> {
|
||||
#[inline]
|
||||
pub fn to_rgba<U:Clone + Channel>(&self) -> RGBA<U> {
|
||||
match unsafe {
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
|
||||
use std::num;
|
||||
|
||||
use color::{Channel, FloatChannel};
|
||||
use color::{Channel, ToChannel, FloatChannel};
|
||||
use color::{HSV, ToHSV};
|
||||
|
||||
#[path = "../num_macros.rs"]
|
||||
|
@ -35,7 +35,7 @@ pub trait ToRGB {
|
|||
pub fn to_rgb<U:Clone + Channel>(&self) -> RGB<U>;
|
||||
}
|
||||
|
||||
impl<T:Clone + Channel> ToRGB for RGB<T> {
|
||||
impl<T:Clone + ToChannel> ToRGB for RGB<T> {
|
||||
#[inline]
|
||||
pub fn to_rgb<U:Clone + Channel>(&self) -> RGB<U> {
|
||||
RGB::new(Channel::from((*self).r.clone()),
|
||||
|
@ -44,7 +44,7 @@ impl<T:Clone + Channel> ToRGB for RGB<T> {
|
|||
}
|
||||
}
|
||||
|
||||
impl<T:Clone + Channel> ToHSV for RGB<T> {
|
||||
impl<T:Clone + ToChannel> ToHSV for RGB<T> {
|
||||
#[inline]
|
||||
pub fn to_hsv<U:Clone + FloatChannel>(&self) -> HSV<U> {
|
||||
// Algorithm taken from the Wikipedia article on HSL and HSV:
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
|
||||
use std::cast;
|
||||
|
||||
use color::{Channel, FloatChannel};
|
||||
use color::{Channel, ToChannel, FloatChannel};
|
||||
use color::{RGB, ToRGB, HSV, ToHSV, HSVA, ToHSVA};
|
||||
|
||||
#[path = "../num_macros.rs"]
|
||||
|
@ -35,7 +35,7 @@ pub trait ToRGBA {
|
|||
pub fn to_rgba<U:Clone + Channel>(&self) -> RGBA<U>;
|
||||
}
|
||||
|
||||
impl<C: ToRGB, T:Clone + Channel> ToRGBA for (C, T) {
|
||||
impl<C: ToRGB, T:Clone + ToChannel> ToRGBA for (C, T) {
|
||||
#[inline]
|
||||
pub fn to_rgba<U:Clone + Channel>(&self) -> RGBA<U> {
|
||||
match *self {
|
||||
|
@ -48,7 +48,7 @@ impl<C: ToRGB, T:Clone + Channel> ToRGBA for (C, T) {
|
|||
}
|
||||
}
|
||||
|
||||
impl<T:Clone + FloatChannel> ToHSVA for RGBA<T> {
|
||||
impl<T:Clone + ToChannel> ToHSVA for RGBA<T> {
|
||||
#[inline]
|
||||
pub fn to_hsva<U:Clone + FloatChannel>(&self) -> HSVA<U> {
|
||||
match unsafe {
|
||||
|
|
Loading…
Reference in a new issue