当前代码从中心转过来。问题:箭头应该只从左端开始:
var box=$(".box");
var boxCenter=[box.offset().left+box.width()/2, box.offset().top+box.height()/2];
$(document).mousemove(function(e){
var angle = Math.atan2(e.pageX- boxCenter[0],- (e.pageY- boxCenter[1]) )*(180/Math.PI);
box.css({ "-webkit-transform": 'rotate(' + angle + 'deg)'});
box.css({ '-moz-transform': 'rotate(' + angle + 'deg)'});
box.css({ 'transform': 'rotate(' + angle + 'deg)'});
});
.box{
background-image:url("Wheelizate Tabs - Apart left_files/tick.png");
width: 200px;
height: 30px;
position: absolute;
left: 200px;
top: 200px;
}
<div class="box" style="z-index:10000;margin-left: 70px;margin-top: 200px;"></div>
答案 0 :(得分:1)
您需要指定transform-origin : center left;
的{{1}}从左侧旋转。默认情况下,box
为transform-origin
。查看工作小提琴https://jsfiddle.net/63qxdg3b/