<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Untitled Document</title>
<style type="text/css">
img {
padding: 1px;
margin: 2px;
float: left;
background-color: #99BC99
}
img.selected {
padding: 2px;
margin: 4px;
background-color: #E13300
}
</style>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$('img').click(function(){
var $elem1 = $(this).parent();
var $elem2 = $('span.last');
$(this).toggleClass('selected');
if ($elem2.length > 0) {
connect($elem1[0], $elem2[0], "#0F0", 5);
} else { $elem1.addClass('last'); }
$('span').removeClass('last');
$elem1.addClass('last');
});
});
function connect(div1, div2, color, thickness) {
var off1 = getOffset(div1);
var off2 = getOffset(div2);
// bottom right
var x1 = off1.left + off1.width;
var y1 = off1.top + off1.height;
// top right
var x2 = off2.left + off2.width;
var y2 = off2.top;
// distance
var length = Math.sqrt(((x2-x1) * (x2-x1)) + ((y2-y1) * (y2-y1)));
// center
var cx = ((x1 + x2) / 2) - (length / 2);
var cy = ((y1 + y2) / 2) - (thickness / 2);
// angle
var angle = Math.atan2((y1-y2),(x1-x2))*(180/Math.PI);
// make hr
var htmlLine = "<div style='padding:0px; margin:0px; height:" + thickness + "px; background-color:" + color + "; line-height:1px; position:absolute; left:" + cx + "px; top:" + cy + "px; width:" + length + "px; -moz-transform:rotate(" + angle + "deg); -webkit-transform:rotate(" + angle + "deg); -o-transform:rotate(" + angle + "deg); -ms-transform:rotate(" + angle + "deg); transform:rotate(" + angle + "deg);' />";
$('body').append($(htmlLine));
}
function getOffset( el ) {
var _x = 0;
var _y = 0;
var _w = el.offsetWidth|0;
var _h = el.offsetHeight|0;
while( el && !isNaN( el.offsetLeft ) && !isNaN( el.offsetTop ) ) {
_x += el.offsetLeft - el.scrollLeft;
_y += el.offsetTop - el.scrollTop;
el = el.offsetParent;
}
return { top: _y, left: _x, width: _w, height: _h };
}
window.testIt = function() {
var div1 = document.getElementById('div1')
var div2 = document.getElementById('div2')
connect(div1, div2, "#0F0", 5);
}
</script>
</head>
<body>
<script type="text/javascript">
</script>
<span style="position: absolute; left: 933px; top: 211px;"> <img src="Untitled-2.jpg" alt="" width="35" height="35" id="div1"/></span>
<span style="position: absolute; left: 304px; top: 190px;"> <img src="Untitled-3.jpg" alt="" width="35" height="35" id="div2"/></span>
<span style="position: absolute; left: 756px; top: 264px;"> <img src="Untitled-4.jpg" alt="" width="35" height="35" id="div3"/></span>
<span style="position: absolute; left: 365px; top: 395px;"> <img src="Untitled-6.jpg" alt="" width="35" height="35" id="div4"/></span>
<span style="position: absolute; left: 129px; top: 302px;"> <img src="Untitled-5.jpg" alt="" width="35" height="35" id="div5"/></span>
<span style="position: absolute; left: 504px; top: 261px;"> <img src="Untitled-7.jpg" alt="" width="35" height="35" id="div6"/></span>
<span style="position: absolute; left: 650px; top: 393px;"> <img src="Untitled-8.jpg" alt="" width="35" height="35" id="div7"/></span>
<span style="position: absolute; left: 283px; top: 26px;"> <img src="Untitled-9.jpg" alt="" width="35" height="35" id="div8"/></span>
<span style="position: absolute; left: 593px; top: 35px;"> <img src="Untitled-10.jpg" alt="" width="35" height="35" id="div9"/></span>
<span style="position: absolute; left: 784px; top: 42px;"> <img src="Untitled-1.jpg" alt="" width="35" height="35" id="div10"/></span>
</body>
</html>
答案 0 :(得分:1)
可能会尝试这个......
$(document).ready(function() {
var currentTrend = 0,
freezed = false;;
$('img').click(function(){
if(freezed) {
return;
}
var currentEl = $(this);
var $elem1 = $(this).parent();
if(currentEl.hasClass("selected")) {
currentEl.toggleClass('selected');
if($elem1.hasClass("last"+currentTrend)) {
$("div.lastLine" + currentTrend).remove();
currentTrend--;
return;
} else if (currentTrend > 2) {
$('body').append('<div class="message">Finished</div>');
freezed = true;
}
}
var $elem2 = $('span.last'+currentTrend);
currentEl.toggleClass('selected');
$('span').removeClass('last');
currentTrend++;
if ($elem2.length > 0) {
lastLine = connect($elem1[0], $elem2[0], "#0F0", 5);
lastLine.addClass('lastLine'+ currentTrend);
}
$elem1.addClass('last' + currentTrend);
});
});
答案 1 :(得分:0)
啊,对不起,我没看到家里的评论:
怎么样?var stop_process = false;
$('img').click(function(){
if( !stop_process ){
if( $(this).hasClass( 'home' ) )
stop_process = true;
if( $('img.home').length == 0 )
$(this).addClass('home');
var $elem1 = $(this).parent();
var $elem2 = $('span.last');
$(this).toggleClass('selected');
if ($elem2.length > 0) {
connect($elem1[0], $elem2[0], "#0F0", 5);
} else { $elem1.addClass('last'); }
$('span').removeClass('last');
$elem1.addClass('last');
}
});
我在这里留下我的第一个回复。也许还有一些有用的东西。 好吧,我的第一个猜测是:
var stop_process = false;
$('img').click(function(){
if( !stop_process ){
if( $(this).hasClass( 'selected' ) )
stop_process = true;
... }
});
但这意味着,我们假设用户点击图像两次,只有当他填满一个圆圈时。也许这对你来说足够了,我不知道剧本的目的。让我们假设这个点击道:
IMG1 - IMG2 - IMG3 - IMG4 - IMG2 IMG2 - ... - IMG2对你来说是一个有效的圈子吗?
如果是这样,你仍然需要避免这种情况计算一个圆圈: IMG1 - IMG2 - IMG1
这是一个快速的方法:
var stop_process = false;
$('img').click(function(){
if( !stop_process ){
if( $(this).hasClass( 'selected' ) && !$(this).parent().hasClass( 'third' ) )
stop_process = true;
var $elem1 = $(this).parent();
var $elem2 = $('span.last');
$(this).toggleClass('selected');
if ($elem2.length > 0) {
$( 'span' ).removeClass( 'third' );
$elem2.addClass( 'third' );
connect($elem1[0], $elem2[0], "#0F0", 5);
} else { $elem1.addClass('last'); }
$('span').removeClass('last');
$elem1.addClass('last');
}
});