Как получить значение цвета с экрана, используя javascript? - PullRequest
0 голосов
/ 27 апреля 2020

У меня есть простой шаблон выбора цвета stati c ниже, я хочу сделать его максимально простым. Я хочу, чтобы при наведении на .color-area мне нужно было получить значение цвета. На самом деле мне нужно получить значение цвета экрана, где моя мышь на самом деле.

Опять же, когда я нажимаю на .hue-bar-value, мне нужно получить цвет и изменить значение .color-area. (Я не хочу использовать какие-либо сторонние библиотеки или плагины, я хочу это в чистом javascript)

Я просто хочу сделать это без холста.

*,
*::before,
*::after
{
  box-sizing: border-box;
}

body{
  margin: 0;
  line-height: 1.5;
  font-weight: 400;
  font-size: 1rem;
  font-family: "Helvetica", Segoe UI, Sans-serif;

}

.html-color-picker  
{
  position: relative;
  width: 100%;
  max-width: 250px;
  height: auto;
  margin: 2rem auto;
  box-shadow: 0 0 8px #ddd;
  
}

.color-area
{
  position: relative;
  width: 100%;
  height: 150px;
  background-color: #fff;
  border-bottom: 1px solid #d1d5da;
   cursor: pointer;
}
.background-color
{
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #007bff;
  
}

.background-black{
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-image: linear-gradient(0deg,rgb(0, 0, 0),rgba(0, 0, 0, 0));
  z-index: 1;
}

.background-white{
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-image: linear-gradient(90deg,rgb(255, 255, 255),rgba(255, 255, 255, 0));
}

.color-controller{
  padding: 1rem;
  font-size: 13px;
  letter-spacing: .5px;
}


.hue-bar{
  position: relative;
  margin-bottom: 1rem;
}

.hue-bar-value{
  height: 10px;
  width: 100%;
  background-image: linear-gradient(90deg,rgb(255, 0, 0) 0,rgb(255, 255, 0) 17%,rgb(0, 255, 0) 33%,rgb(0, 255, 255) 50%,rgb(0, 0, 255) 67%,rgb(255, 0, 255) 83%,rgb(255, 0, 0));
  cursor: pointer;
}

.output{
  border: 1px dotted #ddd;
  padding: .25rem 1rem;
}

.output:focus{
  outline: 0;
}
<div class="html-color-picker">
  
  <div class="color-area">
    <div class="background-color"></div>
    <div class="background-black"></div>
    <div class="background-white"></div>
  </div>
  
  <div class="color-controller">
    <div class="hue-bar">
      <div class="hue-bar-value"></div>
    </div>
    <div class="output" contenteditable="true">
      #007bff
    </div>
  </div>
  
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...