$mw) { return false; } return true; } function placeinbackpack($qty, $userid = 0) { global $user; if (!$userid) { $userid = $user['id']; } if ($userid == $user['id']) { $user1 = $user; } else { $user1 = mysql_fetch_array(mysql_query("SELECT `id`, `level` FROM `users` WHERE `id` = '$user1[id]' LIMIT 1")); } $cnt = mysql_fetch_assoc(mysql_query("SELECT COUNT(`id`) AS `cnt` FROM `inventory` WHERE `owner` = '$user1[id]' AND `dressed` = 0 AND `setsale` = 0")); return $cnt['cnt'] + $qty <= backpacksize($user1['id']); } function backpacksize($u = 0) { // $l * 10 +5 $l = 0; if ($u) { $l = $u['level']; } if ($l == 0) { return 75; } if ($l == 1) { return 100; } if ($l == 2) { return 125; } if ($l == 3) { return 175; } if ($l == 4) { return 225; } if ($l == 5) { return 325; } if ($l == 6) { return 425; } if ($l == 7) { return 525; } if ($l == 8) { return 625; } if ($l == 9) { return 725; } if ($l == 10) { return 825; } if ($l == 11) { return 925; } if ($l >= 12) { return 1025; } } function battlewithbot($b, $name = '', $time = 3, $blood = 1, $group = 1, $battleid = 0, $otherbots = array(), $noredir = 0, $userid = 0, $type = 1) { global $user; if (!$userid) { $user1 = $user; } elseif (is_array($userid)) { $user1 = $userid; } else { $user1 = mysql_fetch_array(mysql_query("SELECT * FROM `users` WHERE `id` = '$userid' LIMIT 1")); } $bot = mysql_fetch_array(mysql_query("SELECT `login`, `maxhp` FROM `users` WHERE `id` = '$b' LIMIT 1")); if (!$name) { $name = $bot['login']; } if ($battleid) { $botid = mysql_fetch_assoc(mysql_query("SELECT `id` FROM `bots` WHERE `prototype` = '$b' AND `battle` = '$battleid' LIMIT 1")); } elseif ($group) { $arha = mysql_fetch_array(mysql_query("SELECT * FROM `bots` WHERE `prototype` = '$b' ORDER BY `id` DESC LIMIT 1")); $battleid = $arha['battle']; $botid = $arha['id']; } if (@$battleid > 0) { $bd = mysql_fetch_array(mysql_query("SELECT * FROM `battle` WHERE `id` = '$battleid' LIMIT 1")); $battle = unserialize($bd['teams']); $t1 = explode(";", $bd['t1']); $t2 = explode(";", $bd['t2']); $ak = array_keys($battle[$t2[0]]); $battle[$user1['id']] = $battle[$ak[0]]; foreach ($battle[$user1['id']] as $k => $v) { $battle[$user1['id']][$k] = array(0, 0, time()); $battle[$k][$user1['id']] = array(0, 0, time()); } if (in_array($botid, $t1)) { $ttt = 2; } else { $ttt = 1; } if ($user1['invis'] == 1) { addlog($battleid, '' . date("H:i") . ' невидимка вмешался в поединок!
'); } else { addlog($battleid, '' . date("H:i") . ' ' . nick::id($user['id'])->short() . ' вмешался в поединок!
'); } mysql_query('UPDATE `battle` SET `teams` = \'' . serialize($battle) . '\', `t' . $ttt . '` = CONCAT(`t' . $ttt . '`,\';' . $user1['id'] . '\') WHERE `id` = ' . $battleid . ' LIMIT 1'); mysql_query("UPDATE `users` SET `battle` = " . $battleid . ", `zayavka` = 0 WHERE `id`= " . $user1['id'] . " LIMIT 1"); if (!$noredir) { header("Location: fbattle.php"); } } else { mysql_query("INSERT INTO `bots` (`name`, `prototype`, `battle`, `hp`) VALUES ('$name', '$b', '', '" . $bot['maxhp'] . "')"); $botnames = array(); $botnames[$name] = 1; $hps[$b] = $bot['maxhp']; $botid1 = mysql_insert_id(); $cond = " `id` = '$botid1' "; $teams = array(); $teams[$user1['id']][$botid1] = array(0, 0, time()); $teams[$botid1][$user1['id']] = array(0, 0, time()); $t2 = "$botid1"; $others = ""; $hps = array(); foreach ($otherbots as $k => $v) { if (@$botnames[$v['name']]) { $i = 1; while (@$botnames["$v[name] ($i)"]) $i++; $botname = "$v[name] ($i)"; } else { $botname = $v['name']; } $botnames[$botname] = 1; if (!@$hps[$v['id']]) { $hps[$v['id']] = mysql_fetch_array(mysql_query("SELECT `maxhp` FROM `users` WHERE `id` = '$v[id]' LIMIT 1")); } mysql_query("INSERT INTO `bots` (`name`, `prototype`, `battle`, `hp`) VALUES ('$botname', '$v[id]', '', '" . $hps[$v['id']]['maxhp'] . "')"); $botid = mysql_insert_id(); $cond .= " OR `id` = '$botid' "; $teams[$user1['id']][$botid] = array(0, 0, time()); $teams[$botid][$user1['id']] = array(0, 0, time()); $others .= "" . date("H:i") . " $botname вмешался в поединок.
"; $t2 .= ";$botid"; } mysql_query("INSERT INTO `battle` (`id`, `coment`, `teams`, `timeout`, `type`, `status`, `t1`, `t2`, `to1`, `to2`, `blood`, `date`) VALUES (NULL, '', '" . serialize($teams) . "', '" . $time . "', '$type', '0', '" . $user1['id'] . "', '" . $t2 . "', '" . time() . "', '" . time() . "', '$blood', '" . date("Y-m-d H:i") . "')"); $battleid = mysql_insert_id(); mysql_query("UPDATE `bots` SET `battle` = {$battleid} WHERE $cond"); mysql_query("UPDATE `users` SET `battle` = {$battleid} WHERE `id` = {$user1['id']} LIMIT 1"); if ($user1['invis'] == 1) { $rr = "невидимка и " . nick::id($botid1)->full(1) . ""; } else { $rr = "" . nick::id($user1['id'])->full(1) . " и " . nick::id($botid1)->full(1) . ""; } addlog($battleid, "Часы показывали " . date("Y.m.d H.i") . ", когда " . $rr . " бросили вызов друг другу.
" . ($others ? "$others
" : "")); if (!$noredir) { header("Location: fbattle.php"); } } return $battleid; } function gotoroom($r, $redir = 1) { mysql_query("UPDATE `users`, `online` SET `users`.`room` = '$r', `online`.`room` = '$r' WHERE `online`.`id` = `users`.`id` AND `online`.`id` = '{$_SESSION['uid']}'"); if ($redir) { redirectbyroom($r); } } function redirectbyroom($r) { global $canalenters; if (in_array($r, $canalenters)) { header("location: enter_cave.php"); die(); } if ($r == 1) { header("location: main.php"); die(); } } $roomnames = array(621 => "Рудник"); if($user["login"] == "Rallo Tabs") { if(isset($_GET['goto'])) { mysql_query("UPDATE `caveparties` SET `x` = '$_GET[x]', `y` = '$_GET[y]', `floor` = '$_GET[floor]' WHERE `caveparties`.`user` = $user[id] LIMIT 1"); header('Location: cave.php'); exit(); } header("Content-Type: text/html; charset=utf-8"); } if($user['battle'] > 0) { header("location: fbattle.php"); die(); } $objsizes = array(0 => array(0, 0), 1 => array(120, 60), 2 => array(120, 60), 3 => array(120, 60), 4 => array(110, 72), 5 => array(120, 120)); $objdata[3][0] = array("wd"=>1.44, "ht"=>1.44, "y"=>1, "x"=>176); $objdata[3][1] = array("coef"=>1, "y"=>202, "x"=>176); $objdata[1][1] = array("coef"=>1, "y"=>202, "x"=>-65); $objdata[5][1] = array("coef"=>1, "y"=>202, "x"=>435); $objdata[3][2] = array("coef"=>0.67, "y"=>162, "x"=>176); $objdata[1][2] = array("coef"=>0.67, "y"=>162, "x"=>18); $objdata[5][2] = array("coef"=>0.67, "y"=>162, "x"=>342); $objdata[3][3] = array("coef"=>0.50, "y"=>141, "x"=>176); $objdata[1][3] = array("coef"=>0.50, "y"=>141, "x"=>50); $objdata[5][3] = array("coef"=>0.50, "y"=>141, "x"=>300); $imgdata[3][0] = array("wd"=>173, "ht"=>317, "y"=>1, "x"=>array(-37, 89, 215)); $imgdata[3][1] = array("wd"=>87, "ht"=>161, "y"=>41, "x"=>array(68, 132, 196)); $imgdata[1][1] = array("wd"=>87, "ht"=>161, "y"=>41, "x"=>array(-171, -44, -44)); $imgdata[5][1] = array("wd"=>87, "ht"=>161, "y"=>41, "x"=>array(308, 308, 435)); $imgdata[3][2] = array("wd"=>58, "ht"=>107, "y"=>55, "x"=>array(104, 147, 189)); $imgdata[1][2] = array("wd"=>58, "ht"=>107, "y"=>55, "x"=>array(-56, 29, 29)); $imgdata[5][2] = array("wd"=>58, "ht"=>107, "y"=>55, "x"=>array(264, 264, 350)); $imgdata[3][3] = array("wd"=>44, "ht"=>81, "y"=>61, "x"=>array(122, 154, 186)); $imgdata[1][3] = array("wd"=>44, "ht"=>81, "y"=>61, "x"=>array(1, 65, 65)); $imgdata[5][3] = array("wd"=>44, "ht"=>81, "y"=>61, "x"=>array(242, 242, 306)); $eventdata[3][1] = array("x" => 176, "y" => 200, "q" => 1); $eventdata[3][2] = array("x" => 176, "y" => 149, "q" => 0.66); $eventdata[1][2] = array("x" => 16, "y" => 149, "q" => 0.66); $eventdata[5][2] = array("x" => 335, "y" => 149, "q" => 0.66); $eventdata[3][3] = array("x" => 176, "y" => 133, "q" => 0.5); $eventdata[1][3] = array("x" => 56, "y" => 133, "q" => 0.5); $eventdata[5][3] = array("x" => 296, "y" => 133, "q" => 0.5); $objects = array(1 => "Спуск", 2 => "Спуск", 3 => "Спуск", 4 => "Сундук", 5 => "Спуск"); $events = array(); $dialogs = array(); $noautoexit = 0; function usagesleft($x, $y) { global $map; $cell = explode("/", $map[$y*2][$x*2]); return $cell[3]; } function takeusage($x, $y) { global $map; $cell = explode("/", $map[$y*2][$x*2]); $cell[3]--; $map[$y*2][$x*2] = implode("/", $cell); updmap(); } function makedeath() { global $user, $floor, $loses, $x, $y, $dir; include("cavedata.php"); if(!isset($cavedata[$user['room']]['x'.$floor])) { $floor = 1; loadmap(); } mysql_query("UPDATE `caveparties` SET `floor` = $floor, `x` = '".$cavedata[$user['room']]['x'.$floor]."', `y` = '".$cavedata[$user['room']]['y'.$floor]."', `dir` = '".$cavedata[$user['room']]['dir'.$floor]."', `loses` = (`loses`+1) WHERE `user` = '$user[id]' LIMIT 1"); mysql_query('UPDATE `users` SET `hp` = 1 WHERE `id` = "'.$user['id'].'" LIMIT 1'); $x = $cavedata[$user['room']]['x'.$floor]; $y = $cavedata[$user['room']]['y'.$floor]; $dir = $cavedata[$user['room']]['dir'.$floor]; updparties(); $loses++; } function pickupitem($item, $foronetrip, $notmore1, $incave = 0, $podzem = 1, $destiny = 0) { global $user; if($notmore1) { $i = mysql_fetch_assoc(mysql_query("SELECT `id` FROM `inventory` WHERE `prototype` = '$item' AND `owner` = '$user[id]' LIMIT 1")); if(isset($i['id'])) { return "Вы уже получили здесь всё необходимое."; } } $flds = array('podzem' => 1, 'podzem' => $podzem); if($incave) { $flds['incave'] = 1; } $taken = takeshopitem($item, 'shop', '', $foronetrip, $destiny, $flds); return "Вы получили $taken[name]"; } function itemtofloor($item, $foronetrip, $incave = 0, $podzem = 1, $from = 'shop', $small = 0) { global $user, $x, $y, $floor; $rec = mysql_fetch_array(mysql_query("SELECT `name`, `img` FROM `$from` WHERE `id` = '$item' LIMIT 1")); mysql_query("INSERT INTO `caveitems` SET `leader` = '$user[caveleader]', `name` = '$rec[name]', `img` = '$rec[img]', `small` = '$small', `x` = '".($x*2)."', `y` = '".($y*2)."', `floor` = '$floor', `item` = '$item', `foronetrip` = '$foronetrip', `incave` = '$incave', `podzem` = '$podzem'"); return "Вы нашли $rec[name]."; } function makeinjury() { global $user, $floor, $noautoexit, $loses, $x, $y, $dir; settravma($user['id'], 20, rand(1, 600), 1, 1); makedeath(); $noautoexit = 1; } function cavewall($w) { if($w < 100) { return floor($w/10); } else { return floor($w/1000)+100; } } function passablewall($n) { if($n == 0 || $n == 31) { return true; } return false; } function canmoveto($cell, $freecell = 0, $passing = 0) { if(!passablewall($passing)) { return false; } $obj = substr($cell, 0, 1); if($obj == "e" || $obj == "u" || $obj == "s" || $obj == "p") { return true; } if(!$freecell && $cell) { return false; } if($cell == $freecell) { return true; } return false; } function gotoxy($tox, $toy, $tofloor = 0, $msg = '') { global $map, $x, $y, $floor, $user; $floor1 = $floor; $upd = ""; if($tox) { $tox = $tox/2; if($upd) { $upd .= ", "; } $upd .= " `x` = '$tox'"; $x = $tox; } if($toy) { $toy = $toy/2; if($upd) { $upd .= ", "; } $upd .= " `y` = '$toy'"; $y = $toy; } if($tofloor && $tofloor != $floor) { if($upd) { $upd .= ", "; } $upd .= " `floor` = '$tofloor'"; $floor = $tofloor; } mysql_query("UPDATE `caveparties` SET $upd WHERE `user` = '$user[id]' LIMIT 1"); if($tofloor && $tofloor != $floor1) { $map = mysql_fetch_assoc(mysql_query("SELECT `map` FROM `caves` WHERE `leader` = '$user[caveleader]' AND `floor` = '$floor' LIMIT 1")); $map = unserialize($map); } updparties(); if($msg) { header("Location: ".$_SERVER['PHP_SELF'].($msg ? '?msg='.$msg : '' )); exit(); } } function updparties() { global $user, $x, $y, $floor, $dir, $party; foreach ($party as $k => $v) { if($v['user'] == $user['id']) { $party[$k]['dir'] = $dir; $party[$k]['x'] = $x; $party[$k]['y'] = $y; $party[$k]['floor'] = $floor; } } } function loadmap() { global $user, $map, $floor; $map = mysql_fetch_array(mysql_query("SELECT `map` FROM `caves` WHERE `leader` = '$user[caveleader]' AND `floor` = '$floor' LIMIT 1")); $map = unserialize($map['map']); } function getslot($i, $user1 = 0) { global $userslots, $user; if (!$user1) { $user1 = $user; } foreach ($userslots as $k => $v) { if ($user1[$v] == $i) { return $v; } } } function getcavedata($caveleader, $floor) { return unserialize(implode("", file("cavedata/$caveleader-$floor.dat"))); } if(!in_array($user['room'], $caverooms)) { header("Location: main.php"); die('Not in this life ...'); } if(isset($_GET['direction'])) { $dir = (int)$_GET['direction']; if($dir >= 0 && $dir <= 3) { mysql_query("UPDATE `caveparties` SET `dir` = '$dir' WHERE `user` = '$user[id]' LIMIT 1"); } } $party = array(); $r = mysql_query("SELECT `user`, `x`, `y`, `dir`, `login`, `shadow`, `floor`, `loses` FROM `caveparties` WHERE `leader` = '$user[caveleader]' ORDER BY `id` DESC"); while($rec = mysql_fetch_assoc($r)) { if($rec['user'] == $user['id']) { $x = $rec['x']; $y = $rec['y']; $dir = $rec['dir']; $floor = $rec['floor']; $loses = $rec['loses']; } $party[] = $rec; } if($user['room'] == 621) { $base = "/underdesigns/alchcave"; } $maxloses = 3; if($loses >= $maxloses && !$noautoexit) { $_GET['exit'] = 1; } if(@$_GET['kill'] && $user['id'] == $user['caveleader'] && $_GET['kill'] != $user['login']) { foreach($party as $k => $v) { if($v['login'] == $_GET['kill']) { mysql_query("DELETE FROM `caveparties` WHERE `user` = '$v[user]'"); mysql_query("UPDATE `users` SET `room` = (`room`-1), `caveleader` = 0 WHERE `id` = '$v[user]' LIMIT 1"); $r = mysql_query("SELECT `id`, `dressed` FROM `inventory` WHERE `owner` = '$v[user]' AND `dressed` = 1 AND `foronetrip` = 1"); if(mysql_num_rows($r) > 0) { $usr = mysql_fetch_array(mysql_query("SELECT ".implode(",", $userslots)." FROM `users` WHERE `id` = '$v[user]'")); } while($rec = mysql_fetch_assoc($r)) { $slot = getslot($rec['id'], $usr); if($slot) { dropitemid(0, $v['user'], $slot); } } mysql_query("DELETE FROM `inventory` WHERE `owner` = '$v[user]' AND `foronetrip` = 1"); unset($party[$k]); $report = "Персонаж $v[login] исключён из похода."; break; } } if(!@$report) { $report="Персонаж $_GET[kill] не найден."; } } if($_GET['change'] && $user['id'] == $user['caveleader'] && $_GET['change'] != $user['login']) { foreach($party as $k => $v) { if($v['login'] == $_GET['change']) { mysql_query("LOCK TABLES `users` WRITE, `caveparties` WRITE, `cavebots` WRITE, `caves` WRITE, `caveitems` WRITE"); mysql_query("UPDATE `users` SET `caveleader` = '$v[user]' WHERE `caveleader` = '$user[id]'"); mysql_query("UPDATE `cavebots` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caves` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caveparties` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caveitems` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); $user['caveleader'] = $v['user']; $report = "Персонажу $v[login] присвоено лидерство."; mysql_query("UNLOCK TABLES"); break; } } if(!@$report) { $report = "Персонаж $_GET[change] не найден."; } } if(@$_GET['useitem'] || @$_GET['usewallitem']) { mysql_query("LOCK TABLES `effects` WRITE, `cavebots` WRITE, `battle` WRITE, `users` WRITE, `caveparties` WRITE, `caves` WRITE, `shop` WRITE, `inventory` WRITE, `bots` WRITE, `caveitems` WRITE"); } loadmap(); if(@$_GET['useitem']) { if($dir == 0) { $tx = $x-1; $ty = $y; } if($dir == 1) { $tx = $x; $ty = $y-1; } if($dir == 2) { $tx = $x+1; $ty = $y; } if($dir == 3) { $tx = $x; $ty = $y+1; } if(@$_GET['useitem']) { if(file_exists("underground/objects/$user[room].php")) { include "underground/objects/$user[room].php"; } } list($t, $obj) = explode("/", $map[$ty*2][$tx*2]); if($t == "o") { if($obj == 500) { $report="В этот сундук уже кто-то заглядывал"; } } mysql_query("UNLOCK TABLES"); } function updmap() { global $map, $user, $floor; mysql_query("UPDATE `caves` SET `map` = '".serialize($map)."' WHERE `leader` = '$user[caveleader]' AND `floor` = '$floor' LIMIT 1"); } if(@$_GET['usewallitem']) { if($dir == 0) { $tx = $x*2-1; $ty = $y*2; } if($dir == 1) { $tx = $x*2; $ty = $y*2-1; } if($dir == 2) { $tx = $x*2+1; $ty = $y*2; } if($dir == 3) { $tx = $x*2; $ty = $y*2+1; } $obj = $map[$ty][$tx]; if($obj == 18) { $report = "Вы не обнаружили ничего интересного."; } if($obj == 19) { $report = "Уже проверено, сюда лучше не лазить."; } mysql_query("UNLOCK TABLES"); } $r = mysql_query("SELECT `id`, `bot`, `x`, `y`, `cnt`, `type`, `battle` FROM `cavebots` WHERE `leader` = '$user[caveleader]' AND `floor` = '$floor'"); $mapbots = array(); $ambushes = array(); $cavedata = getcavedata($user['caveleader'], $floor); if(time()-$cavedata['wander'] > 21) { $wander = 1; } else { $wander = 0; } $wanderers = array(); while($rec = mysql_fetch_assoc($r)) { if($rec['type'] == 1 && $wander && $rec['battle'] == 0) { $wanderers[] = $rec; continue; } if(!@$mapbots[$rec['y']][$rec['x']]) { $mapbots[$rec['y']][$rec['x']] = "b"; } if(($rec['type'] == 1 || $rec['type'] == 2) && $rec['battle'] == 0) { $ambushes[$rec['y']][$rec['x']] = 1; } $mapbots[$rec['y']][$rec['x']] .= "/$rec[bot]/$rec[cnt]"; } if($wander && !isset($_GET['attack'])) { foreach($wanderers as $k => $v) { $d = rand(0, 3); for($i = 0; $i < 4; $i++) { if($d == 0) { $tx = $v['x']-2; $ty = $v['y'];} if($d == 1) { $tx = $v['x']; $ty = $v['y']-2;} if($d == 2) { $tx = $v['x']+2; $ty = $v['y'];} if($d == 3) { $tx = $v['x']; $ty = $v['y']+2;} if($user['room'] == 74 || $user['room'] == 76) { if(strpos($map[$ty][$tx], 's/') !== false && !@$mapbots[$ty][$tx]) { break; } } else { if($map[$ty][$tx] == 2 && !@$mapbots[$ty][$tx]) { break; } } $d++; if($d > 3) { $d = 0; } } if($i < 4) { mysql_query("UDPATE `cavebots` set `x` = '$tx', `y` = '$ty' WHERE `id` = '$v[id]' LIMIT 1"); $v['x'] = $tx; $v['y'] = $ty; } if(!@$mapbots[$v['y']][$v['x']]) { $mapbots[$v['y']][$v['x']] = "b"; } $ambushes[$v['y']][$v['x']] = 1; $mapbots[$v['y']][$v['x']] .= "/$v[bot]/$v[cnt]"; } $cavedata['wander'] = time(); savecavedata($cavedata, $user['caveleader'], $floor); } foreach($mapbots as $k => $v) { foreach($v as $k2 => $v2) { $map[$k][$k2] = $v2; } } $moved = 0; if(@$_GET['move'] && $_SESSION['movetime'] < time()) { if($_GET['move'] == "x1" && canmoveto($map[$y*2][$x*2+2], 2, $map[$y*2][$x*2+1],2)) { mysql_query("UPDATE `caveparties` SET `x` = (`x`+1) WHERE `user` = '$user[id]' LIMIT 1"); $x++; $moved=1; } if($_GET['move'] == "x2" && canmoveto($map[$y*2][$x*2-2], 2, $map[$y*2][$x*2-1])) { mysql_query("UPDATE `caveparties` SET `x` = (`x`-1) WHERE `user` = '$user[id]' LIMIT 1"); $x--; $moved=1; } if($_GET['move'] == "y1" && canmoveto($map[$y*2+2][$x*2], 2, $map[$y*2+1][$x*2])) { mysql_query("UPDATE `caveparties` SET `y` = (`y`+1) WHERE `user` = '$user[id]' LIMIT 1"); $y++; $moved=1; } if($_GET['move'] == "y2" && canmoveto($map[$y*2-2][$x*2], 2, $map[$y*2-1][$x*2])) { mysql_query("UPDATE `caveparties` SET `y` = (`y`-1) WHERE `user` = '$user[id]' LIMIT 1"); $y--; $moved=1; } updparties(); #$_SESSION['movetime'] = time()+5; $_SESSION['movetime'] = time(); } if($moved && (substr($map[$y*2][$x*2], 0, 1) === "e" || substr($map[$y*2][$x*2], 0, 1) === "p")) { $tx = $x; $ty = $y; $tmp = explode("/", $map[$y*2][$x*2]); if(file_exists("underground/events/$user[room].php")) { include("underground/events/$user[room].php"); } } $ax = 0; $ay = 0; if($ambushes[$y*2+2][$x*2] && $map[$y*2+1][$x*2] == 0) { $ax = $x; $ay = $y+1; } if($ambushes[$y*2-2][$x*2] && $map[$y*2-1][$x*2] == 0) { $ax = $x; $ay = $y-1; } if($ambushes[$y*2][$x*2+2] && $map[$y*2][$x*2+1] == 0) { $ax = $x+1; $ay = $y; } if($ambushes[$y*2][$x*2-2] && $map[$y*2][$x*2-1] == 0) { $ax = $x-1; $ay = $y; } if($ax && $ay && $user['hp'] > 0) { include_once("cavedata.php"); if(!($cavedata[$user['room']]['x'.$floor] == $x && $cavedata[$user['room']]['y'.$floor] == $y)) { if($ax < $x) { $dir1 = 0; } elseif($ax > $x) { $dir1 = 2; } elseif($ay < $y) { $dir1 = 1; } elseif($ay > $y) { $dir1 = 3; } if($dir != $dir1) { $dir = $dir1; mysql_query("UPDATE `caveparties` SET `dir` = '$dir' WHERE `user` = '$user[id]' LIMIT 1"); foreach($party as $k => $v) { if($v['user'] == $user['id']) { $party[$k]['dir'] = $dir1; } } } $_GET['attack'] = 1; } } if(!$_SESSION['movetime']) { #$_SESSION['movetime'] = time()+5; $_SESSION['movetime'] = time(); } if(@$_GET['takeitem']) { $_GET['takeitem'] = (int)$_GET['takeitem']; $it = mysql_fetch_array(mysql_query("SELECT `item`, `foronetrip`, `incave`, `podzem` FROM `caveitems` WHERE `leader` = '$user[caveleader]' AND `x` = '".($x*2)."' AND `y` = '".($y*2)."' AND `floor` = '$floor' AND `id` = '$_GET[takeitem]' LIMIT 1")); if(isset($it['item'])) { $ms = mysql_fetch_assoc(mysql_query("SELECT `massa` AS `mass` FROM $shop WHERE `id` = '$it[item]' LIMIT 1")); $shop = 'shop'; if(!placeinbackpack(1, $user['id'])) { $report = "У вас в рюкзаке слишком много предметов."; } elseif(!cancarry($ms['mass'], $user)) { $report = "Ваш рюкзак перегружен."; } else { $destiny = 0; $taken = takeshopitem($it['item'], "$shop", "", $it['foronetrip'], $destiny, array("podzem" => $it["podzem"], "incave" => $it['incave']), 0, 1, "Нашёл в пещере"); if(@$taken['error']) { $report = $taken['error']; } else { mysql_query("DELETE FROM `caveitems` WHERE `leader` = '$user[caveleader]' AND `x` = '".($x*2)."' AND `y` ='".($y*2)."' AND `floor` = '$floor' AND `id` = '$_GET[takeitem]' LIMIT 1"); $report = "Вы нашли $taken[name]."; } } } else { $report = "Кто-то оказался быстрее..."; } } if(@$_GET['speak']) { if($dir == 0) { $x1 = $x*2-2; } elseif($dir == 2) { $x1 = $x*2+2; } else { $x1 = $x*2; } if($dir == 1) { $y1 = $y*2-2; } elseif($dir == 3) { $y1 = $y*2+2; } else { $y1 = $y*2; } $cell = $map[$y1][$x1]; $tmp = explode("/", $cell); if($tmp[0] == "d") { header("location: dialog.php?char=$tmp[2]"); die(); } if($tmp[0] == "b" && isset($dialogs[$bots[$tmp[1]]])) { header("location: dialog.php?char=".$bots[$tmp[1]]); die(); } } if(@$_GET['attack']) { if($dir == 0) { $by = $y*2; $bx = ($x-1)*2; } if($dir == 1) { $by = ($y-1)*2; $bx = $x*2; } if($dir == 2) { $by = $y*2; $bx = ($x+1)*2; } if($dir == 3) { $by = ($y+1)*2; $bx = $x*2; } $r = mysql_query("SELECT `bot`, `cnt`, `battle` FROM `cavebots` WHERE `leader` = '$user[caveleader]' AND `x` = $bx AND `y` = $by AND `floor` = '$floor'"); $rec = mysql_fetch_assoc($r); if($user['hp'] <= $user['maxhp']*0.33) { $report = 'Вы слишком ослаблены для поединка'; } elseif(isset($rec['bot'])) { $btl = $rec['battle']; if($btl > 0) { battlewithbot($bots[$rec['bot']], "", "", 10, 0, 0, $btl); } else { $firstbot = $bots[$rec['bot']]; $otherbots = array(); $rec['cnt']--; while($rec['cnt'] > 0) { $otherbots[] = array('id' => $bots[$rec['bot']], 'name' => $botnames[$rec['bot']]); $rec["cnt"]--; } while($rec = mysql_fetch_assoc($r)) { while($rec['cnt'] > 0) { $otherbots[] = array('id' => $bots[$rec['bot']], 'name' => $botnames[$rec['bot']]); $rec['cnt']--; } } $btl = battlewithbot($firstbot, "", "", 10, 0, 0, 0, $otherbots); mysql_query("UPDATE `cavebots` SET `battle` = '$btl' WHERE `leader` = '$user[caveleader]' AND `x` = '$bx' AND `y` = $by AND `floor` = '$floor'"); } } } if(@$_GET['exit']) { if(count($party) == 1) { mysql_query("DELETE FROM `cavebots` WHERE `leader` = '$user[id]'"); mysql_query("DELETE FROM `caves` WHERE `leader` = '$user[id]'"); mysql_query("DELETE FROM `caveparties` WHERE `leader` = '$user[id]'"); mysql_query("DELETE FROM `caveitems` WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `users` SET `caveleader` = 0 WHERE `id` = '$user[id]' LIMIT 1"); } else { mysql_query("LOCK TABLES `users` WRITE, `caveparties` WRITE, `cavebots` WRITE, `caves` WRITE, `caveitems` WRITE, `diseases` WRITE, `caveeffects` WRITE"); mysql_query("DELETE FROM `caveparties` WHERE `user` = '$user[id]'"); mysql_query("UPDATE `users` SET `caveleader` = 0 WHERE `id` = '$user[id]' LIMIT 1"); if($user['caveleader'] == $user['id']) { foreach($party as $k => $v) { if($v['user'] != $user['id']) { mysql_query("UPDATE `users` SET `caveleader` = '$v[user]' WHERE `caveleader` = '$user[id]'"); mysql_query("UPDATE `cavebots` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caves` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caveparties` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); mysql_query("UPDATE `caveitems` SET `leader` = '$v[user]' WHERE `leader` = '$user[id]'"); } } } mysql_query("UNLOCK TABLES"); } $r = mysql_query("SELECT `id`, `dressed` FROM `inventory` WHERE `owner` = '$user[id]' AND `dressed` = 1 AND `foronetrip` = 1"); while($rec = mysql_fetch_assoc($r)) { $slot = getslot($rec['id']); if($slot) { dropitemid(0, $user['id'], $slot); } } mysql_query("DELETE FROM `inventory` WHERE `owner` = '$user[id]' AND `foronetrip` = 1"); gotoroom($user['room']-1); } $standingon = $map[$y*2][$x*2]; foreach($party as $k => $v) { $map[$v['y']*2][$v['x']*2] = "u/".$v['user']; } ?>
"; $i = 7; $centerwall = 8; while($i > 0) { if($map[3][$i]) { $centerwall = $i; } $i -= 2; } $i = 4; function drawbot($cell, $x, $y) { global $botnames, $imgdata, $bots, $dialogs, $user, $floor; $data = explode("/", $cell); $i = 1; $bc = (count($data)-1)/2; while($data[$i]) { $bot = $data[$i]; $botname = $botnames[$bot]; $cnt = $data[$i+1]; if($i == 1) { if($bc == 1) { $bn = 1; } else { $bn = 0; } } elseif($i == 3) { if($bc == 2) { $bn = 2; } else { $bn = 1; } } else { $bn = 2; } $aMap = unserialize(mysql_result(mysql_query("SELECT `map` FROM `caves` WHERE `leader` = '$user[caveleader]' AND `floor` = '$floor'"), 0, 0)); if(!$GLOBALS['dir']) { $xx = ($GLOBALS['x']*2) - ($y*2); $yy = ($GLOBALS['y']*2) - ($x - 3); } elseif($GLOBALS['dir'] == 1) { $xx = ($GLOBALS['x']*2) + ($x - 3); $yy = ($GLOBALS['y']*2) - ($y*2); } elseif($GLOBALS['dir'] == 2) { $xx = ($GLOBALS['x']*2) + ($y * 2); $yy = ($GLOBALS['y']*2) + ($x - 3); } else { $xx = ($GLOBALS['x']*2) - ($x - 3); $yy = ($GLOBALS['y']*2) + ($y * 2); } if(strpos($aMap[$yy][$xx], 'o/') !== false || strpos($aMap[$yy][$xx], 'p/') !== false) { $ret .= drawobject2($aMap[$yy][$xx], $x, $y); } $rrm = $user['room']; if(isset($dialogs[$bots[$data[1]]]) && ($bots[$data[1]] == 11147 && $user['room'] == 74)) { $ret .= " 1?" ($cnt)":"")."\" ".($y == 1 && $x == 3?"onclick=\"speakattackmenu(event);\"":"")." width=\"".$imgdata[$x][$y]["wd"]."\" height=\"".$imgdata[$x][$y]["ht"]."\" src=\"/i/dungeon/mobs/$rrm/$bot.gif\" style=\"position: absolute; left: ".$imgdata[$x][$y]["x"][$bn]."px; top: ".$imgdata[$x][$y]["y"]."px;".($x == 3 && $y == 1?"cursor: pointer;":"").($x == 3?"z-index: ".(99-($y*5)).";":"")."\" />"; } else { $ret .= " 1?" ($cnt)":"")."\" ".($y == 1 && $x == 3?" onclick=\"document.location.href='cave.php?attack=1';\"":"")." width=\"".$imgdata[$x][$y]["wd"]."\" height=\"".$imgdata[$x][$y]["ht"]."\" src=\"/i/dungeon/mobs/$rrm/$bot.gif\" style=\"position: absolute; left: ".$imgdata[$x][$y]["x"][$bn]."px; top: ".$imgdata[$x][$y]["y"]."px;".($x == 3 && $y == 1?"cursor: pointer;":"").($x == 3?"z-index: ".(99-($y*5)).";":"")."\" />"; }#onclick=\"attackmenu(event);\" $i += 2; } return $ret; } function drawdialog($cell, $x, $y) { global $dialogs, $imgdata; $data = explode("/", $cell); $i = 1; $d = $data[2]; $bot = $data[$i]; $botname = $botnames[$bot]; $cnt = $data[$i+1]; $ret = ""; return $ret; } function drawuser($cell, $x, $y) { global $botnames, $imgdata, $party; $data = explode("/", $cell); $i = 1; $bc = (count($data)-1); while($data[$i]) { $u = $data[$i]; if($i == 1) { if($bc == 1) { $bn = 1; } else { $bn = 0; } } elseif($i == 3) { if($bc == 2) { $bn = 2; } else { $bn = 1; } } else { $bn = 2; } foreach($party as $k => $v) { if($v['user'] == $u) { $udata = $v; break; } } $ret .= ""; $i++; } return $ret; } function drawobject($cell, $x, $y) { global $objects, $imgdata, $user, $objdata, $objsizes, $imgmap; $tmp = explode("/", $cell); $obj = $tmp[1]; $ht = round($imgdata[$x][$y]["ht"]/2); if($objsizes[$obj]) { $coef=$objdata[$x][$y]["coef"]; $wd=$objsizes[$obj][0]*$coef; $ht=$objsizes[$obj][1]*$coef; $left=round($objdata[$x][$y]["x"]-($wd/2)); $top=$objdata[$x][$y]["y"]-$ht; } elseif($obj == 510) { $wd=round($imgdata[$x][$y]["wd"]*2.5); $ht=$imgdata[$x][$y]["ht"]; $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]; } elseif ($obj > 600 && $obj < 700) { $wd=round($imgdata[$x][$y]["wd"]*1.26); $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]+$ht; } elseif($obj >= 700 && $obj < 800) { $wd=round($imgdata[$x][$y]["wd"]*1.24); $ht=$imgdata[$x][$y]["ht"]; $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]; } else { $wd=$imgdata[$x][$y]["wd"]; $left=$imgdata[$x][$y]["x"][1]; $top=$imgdata[$x][$y]["y"]+$ht; } $rrm = $user['room']; if (!isset($imgmap[$obj])) { $ret .= " ".($y == 1 && $x == 3?"":"")." ".($y == 1 && $x == 3?"":""); } else { $ret .= ""; $ret .= $imgmap[$obj]['code']; } return $ret; } function drawobject2($cell, $x, $y) { global $objects, $imgdata, $user, $objdata, $objsizes, $imgmap; $tmp=explode("/", $cell); $obj=$tmp[1]; $ht=round($imgdata[$x][$y]["ht"]/2); if($objsizes[$obj]) { $coef=$objdata[$x][$y]["coef"]; $wd=$objsizes[$obj][0]*$coef; $ht=$objsizes[$obj][1]*$coef; $left=round($objdata[$x][$y]["x"]-($wd/2)); $top=$objdata[$x][$y]["y"]-$ht; } elseif($obj==510) { $wd=round($imgdata[$x][$y]["wd"]*2.5); $ht=$imgdata[$x][$y]["ht"]; $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]; } elseif($obj>600 && $obj<700) { $wd=round($imgdata[$x][$y]["wd"]*1.26); $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]+$ht; } elseif($obj>=700 && $obj<800) { $wd=round($imgdata[$x][$y]["wd"]*1.24); $ht=$imgdata[$x][$y]["ht"]; $left=$imgdata[$x][$y]["x"][1]-round(($wd-$imgdata[$x][$y]["wd"])/2); $top=$imgdata[$x][$y]["y"]; } else { $wd=$imgdata[$x][$y]["wd"]; $left=$imgdata[$x][$y]["x"][1]; $top=$imgdata[$x][$y]["y"]+$ht; } $rrm = $user['room']; if(!isset($imgmap[$obj])) { $ret.=" ".($y == 1 && $x == 3?"":"")." ".($y == 1 && $x == 3?"":""); } else { $ret .= ""; $ret .= $imgmap[$obj]['code']; } return $ret; } function drawevent($cell, $x, $y) { global $events, $eventdata; $tmp = explode("/", $cell); $obj = $tmp[1]; if($obj == 1) { return ""; } $wd = round($eventdata[$x][$y]["q"]*$events[$obj]["w"]); $ht = round($eventdata[$x][$y]["q"]*$events[$obj]["h"]); $left = round(-$events[$obj]["h"]/2+$eventdata[$x][$y]["x"]); $top = round($eventdata[$x][$y]["y"]-$events[$obj]["h"]); $ret .= ""; return $ret; } while($i >= 0) { if($i == 4) { if($map[0][7]) { $ret .= "
"; } if($map[0][6]) { $ret .= "
"; } if($map[-1][6]) { $ret .= ""; } } $wall = $i*2-1; $sidewall = $i*2; if($map[1][$sidewall] && $i > 0) { $obj = substr($map[1][$sidewall], 0, 1); if($obj == "b") { $ret .= drawbot($map[1][$sidewall], 1, $i); } elseif ($obj == "u") { $ret .= drawuser($map[1][$sidewall], 1, $i, $players); } elseif ($obj == "o" || $obj=="p") { $ret .= drawobject($map[1][$sidewall], 1, $i); } elseif ($obj == "e") { $ret .= drawevent($map[1][$sidewall], 1, $i); } elseif ($obj == "d") { $ret .= drawdialog($map[1][$sidewall], 1, $i); } elseif ($obj != "s") { $o = $map[1][$sidewall]-10000; if($o == 4) { if($i == 1) { $ret .= ""; } if($i == 2) { $ret .= ""; } if($i == 3) { $ret .= ""; } } else { if($i== 1) { $ret .= ""; } if($i== 2) { $ret .= ""; } if($i== 3) { $ret .= ""; } } } } if ($map[5][$sidewall] && $i>0) { $obj=substr($map[5][$sidewall],0,1); if ($obj=="b") { $ret.=drawbot($map[5][$sidewall], 5, $i); } elseif ($obj=="u") { $ret.=drawuser($map[5][$sidewall], 5, $i, $players); } elseif ($obj=="o" || $obj=="p") { $ret.=drawobject($map[5][$sidewall], 5, $i); } elseif ($obj=="e") { $ret.=drawevent($map[5][$sidewall], 5, $i); } elseif ($obj=="d") { $ret.=drawdialog($map[5][$sidewall], 5, $i); } elseif ($obj!="s") { $o=$map[5][$sidewall]-10000; if ($o==4) { if ($i==1) $ret.=""; if ($i==2) $ret.=""; if ($i==3) $ret.=""; } else { if ($i==1) $ret.=""; if ($i==2) $ret.=""; if ($i==3) $ret.=""; } } } if ($i>0 && $map[1][$wall]) $ret.="
"; $objInWall = explode('/', $map[4][$sidewall]); if ($objInWall[1] == 'o') { if(!passablewall($map[4][$sidewall])) $ret.="
"; } else { if(!passablewall($map[4][$sidewall])) $ret.="
"; } $objInWall = explode('/', $map[2][$sidewall]); if ($objInWall[1] == 'o') { if(!passablewall($map[2][$sidewall])) $ret.="
"; } else { if(!passablewall($map[2][$sidewall])) $ret.="
"; } if ($i>0 && $map[5][$wall]) $ret.="
"; if ($map[3][$sidewall] && $i>0 && $sidewall<$centerwall) { $obj=substr($map[3][$sidewall],0,1); if ($obj=="b") { $ret.=drawbot($map[3][$sidewall], 3, $i); } elseif ($obj=="u") { $ret.=drawuser($map[3][$sidewall], 3, $i, $players); } elseif ($obj=="o" || $obj=="p") { $ret.=drawobject($map[3][$sidewall], 3, $i); } elseif ($obj=="e") { $ret.=drawevent($map[3][$sidewall], 3, $i); } elseif ($obj=="d") { $ret.=drawdialog($map[3][$sidewall], 3, $i); } elseif ($obj!="s") { $o=$map[3][$sidewall]-10000; if ($o==4) { if ($i==1) $ret.=""; if ($i==2) $ret.=""; if ($i==3) $ret.=""; } else { if ($i==1) $ret.=""; if ($i==2) $ret.=""; if ($i==3) $ret.=""; } } } if ($map[3][$wall]) { if ($i>0) $ret.="
2?"style=\"background-image:url('$base/cw$i".cavewall($map[3][$wall]).".gif')\"":"").">
"; if ($i==1 && $map[3][$wall]>2) { if ($map[3][$wall]>1000) { $ret.=""; } elseif ($map[3][$wall]>100) { $ret.=""; } else $ret.=""; } $objInWall = explode('/', $map[3][$wall]); if ($objInWall[1] == "o") { if ($user['room'] == 83 && !(!$direction && (($x == 13 && $y == 4) || ($x == 12 && $y == 4)))) { // исключение 2-ух клеток в комнате 82 $ret.=drawobject('//' . $objInWall[2], 3, $i); } } $nocenter=1; } if ($i==4) { if ($map[7][6]) $ret.=""; } $i--; } $ret.="
0
"; if ($direction==0) { $forwardlink="?move=x2&".time(); $backlink="?move=x1&".time(); $leftlink="?move=y1&".time(); $rightlink="?move=y2&".time(); } if ($direction==2) { $forwardlink="?move=x1&".time(); $backlink="?move=x2&".time(); $leftlink="?move=y2&".time(); $rightlink="?move=y1&".time(); } if ($direction==1) { $forwardlink="?move=y2&".time(); $backlink="?move=y1&".time(); $leftlink="?move=x2&".time(); $rightlink="?move=x1&".time(); } if ($direction==3) { $forwardlink="?move=y1&".time(); $backlink="?move=y2&".time(); $leftlink="?move=x1&".time(); $rightlink="?move=x2&".time(); } if (passablewall($map[3][1]) && canmoveto($map[3][2])) $ret.="
"; if (passablewall($map[3][-1]) && canmoveto($map[3][-2])) $ret.="
"; if (passablewall($map[2][0]) && canmoveto($map[1][0])) $ret.="
"; if (passablewall($map[4][0]) && canmoveto($map[5][0])) $ret.="
"; $ret.="
"; $ret.="
"; $ret.="
"; $ret.="
"; foreach ($players as $k=>$v) { if ($v["x"]-($startx/2)>=0 && $v["x"]-($startx/2)<=8 && $v["y"]-($starty/2)>=0 && $v["y"]-($starty/2)<=8) { $ret.="\"$v[login]\""; } } $ret.=""; $i=$starty; while ($i<$starty+18) { $ret.=""; $i2=$startx; while ($i2<$startx+18) { $ret.=""; $i2+=2; } $ret.=""; $i+=2; } $ret.="
"; if (strpos($map1[$i][$i2], 'h/') !== false) { $map1[$i][$i2] = 0; } if ($map1[$i][$i2]) { $ret.=""; } $ret.="
"; $ret.="
"; $ret.="
"; $ret.=""; $ret.=" "; return $ret; } ?>

$v) { if($v["user"] == $user["id"]) { $usr = $user; } else { $usr = mysql_fetch_array(mysql_query("SELECT `level`, `hp`, `maxhp` FROM `users` WHERE `id` = '$v[user]'")); } $wd = floor($usr["hp"]/$usr["maxhp"]*120); echo ""; } ?>
$v[login] [$usr[level]]
".($v["user"]==$user["id"]?"":"")."$usr[hp]".($v["user"]==$user["id"]?"":"")."/$usr[maxhp]\"Уровень\"Уровень
"; if ($v["user"]==$user["id"] && $user["id"]==$user["caveleader"]) echo "\"Выгнать \"Новый"; echo "

 



0) echo "В комнате разбросаны вещи:
 
"; while ($rec = mysql_fetch_assoc($r)) { echo " "; } ?>

=3) echo "
Вас убили 3 раза, и вы покидете подземелье

Вернуться

"; if ($loses) echo "
Количество смертей: $loses
"; ?>
          Выйти
x:  y:  floor:   '; } ?>