Color.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace Grafika;
  3. /**
  4. * Holds the color information.
  5. * @package Grafika
  6. */
  7. class Color {
  8. /**
  9. * @var string Hex string: #FFFFFF
  10. */
  11. protected $hexString;
  12. /**
  13. * @var float Transparency value 0-1
  14. */
  15. protected $alpha;
  16. /**
  17. * Color constructor.
  18. *
  19. * @param string $hexString Hex string
  20. * @param float $alpha Transparency value 0-1
  21. */
  22. public function __construct( $hexString = '', $alpha = 1.0 ){
  23. $this->hexString = $hexString; // TODO: Validate hexstring
  24. $this->alpha = $alpha;
  25. }
  26. /**
  27. * Get RGB array
  28. *
  29. * @return array Contains array($r, $g, $b)
  30. */
  31. public function getRgb(){
  32. return $this->hexToRgb( $this->hexString );
  33. }
  34. /**
  35. * Get RGBA array
  36. *
  37. * @return array Contains array($r, $g, $b, $a)
  38. */
  39. public function getRgba(){
  40. $rgba = $this->hexToRgb( $this->hexString );
  41. $rgba[] = $this->alpha;
  42. return $rgba;
  43. }
  44. /**
  45. * Convert hex string to RGB
  46. * @param string $hex Hex string. Possible values: #ffffff, #fff, fff
  47. * @return array Contains (RGB) values red, green and blue
  48. */
  49. public function hexToRgb( $hex ) {
  50. $hex = ltrim($hex, '#'); // Remove #
  51. if(strlen($hex) == 3) {
  52. $r = hexdec(substr($hex,0,1).substr($hex,0,1));
  53. $g = hexdec(substr($hex,1,1).substr($hex,1,1));
  54. $b = hexdec(substr($hex,2,1).substr($hex,2,1));
  55. } else {
  56. $r = hexdec(substr($hex,0,2));
  57. $g = hexdec(substr($hex,2,2));
  58. $b = hexdec(substr($hex,4,2));
  59. }
  60. return array($r, $g, $b); // Returns an array with the rgb values
  61. }
  62. /**
  63. * Get hex string.
  64. *
  65. * @return string
  66. */
  67. public function getHexString() {
  68. return $this->hexString;
  69. }
  70. /**
  71. * Set hex string.
  72. *
  73. * @param string $hexString
  74. */
  75. public function setHexString($hexString) {
  76. $this->hexString = $hexString;
  77. }
  78. /**
  79. * Alpha value.
  80. * @return float
  81. */
  82. public function getAlpha() {
  83. return $this->alpha;
  84. }
  85. /**
  86. * @param float $alpha
  87. */
  88. public function setAlpha($alpha) {
  89. $this->alpha = $alpha;
  90. }
  91. }