繁体   English   中英

如何改变鼠标移动的梯度程度?

[英]How to change degree of gradient on mouse movement?

我从http://codepen.io/andreasstorm/pen/syvoL的这段代码sinppet中得到了启发

HTML-

<header>
    <div id="range"></div>
      <div id="currentVal">background-image: linear-gradient( <span id="spanVal">180</span>deg , <span style="color:#4ac1ff">#4ac1ff</span>, <span style="color:#795bb0">#795bb0</span> )</div>
</header>
<div class="gradient"></div>

CSS(手写笔)-

 html
  height 100%

 body
  background-color #292c2f
  font-family monospace
  overflow hidden

 .gradient
  height calc(100% - 70px)
  background-image linear-gradient(180deg,#4ac1ff,#795bb0)
  position absolute
  width 100%

 header
  background #252525
  height 70px
  line-height 70px

 #currentVal
  color #424242
  font-size 14px
  font-weight 800
  padding-left 240px
  span
    color #ccc

 #range
  width 180px
  border 0
  height 4px
  background #424242
  outline none
  position absolute
  left 30px
  top 32px
  .ui-slider-handle
    position absolute
    margin 0px 0 0 -7px
    border-radius 100%
    background white
    border 0
    height 14px
    width 14px
    outline none
    cursor pointer
    &:hover
    &:focus
      transform scale(1.1)
  .ui-slider-range
    background #4ac1ff

JavaScript(coffeeScript)-

$("#range").slider
  range: "min"
  max: 360
  value: 180
  slide: (e, ui) ->
    $("#spanVal").html ui.value
    bg = "linear-gradient(" + ui.value + "deg,#4ac1ff,#795bb0)"
    $(".gradient").css "background-image", bg

以同样的方式,尽管我不太了解JavaScript,但我还是尝试在网页的背景上实现它。 无论如何,我们可以对鼠标移动实现相同的效果吗? 我的意思是更改渐变程度以及光标在屏幕上的位置。

任何帮助将不胜感激!

呢? 您在找什么

$(".gradient").mousemove(function( event ) {
  var w = $(this).width(),
      pct = 360*(+event.pageX)/w,
      bg = "linear-gradient(" + pct + "deg,#4ac1ff,#795bb0)";
      $(".gradient").css("background-image", bg);
});

我只使用x运动。 您可以使用自己喜欢的东西。 用户使用.gradient类在div上移动鼠标。 我只是使用div的宽度将值调整为百分比,然后更改背景。

加x + y并赋予随机deg

 var originalBG = $(".gradient").css("background"); $('.gradient') .mousemove(function(e) { x = e.pageX - this.offsetLeft; y = e.pageY - this.offsetTop; xy = x + y; bgWebKit = "linear-gradient(" + xy + "deg, #4ac1ff, #795bb0)"; $(this).css({ 'background': bgWebKit }) }).mouseleave(function() { $(this).css({ background: originalBG }); }); 
 * { margin: 0; padding: 0; } html { height: 100%; } body { background-color: #292c2f; font-family: monospace; overflow: hidden; } .gradient { height: calc(100%); background: -webkit-linear-gradient(270deg, #4ac1ff, #795bb0); background: -moz-linear-gradient(270deg, #4ac1ff, #795bb0); background: -o-linear-gradient(270deg, #4ac1ff, #795bb0); background: -ms-linear-gradient(270deg, #4ac1ff, #795bb0); background: linear-gradient(180deg, #4ac1ff, #795bb0); position: absolute; width: 100%; } 
 <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> <div class="gradient"></div> 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM