const InputHelper = require("inputhelper"); var show = false; var showAdmin = false; const { x: screenX, y: screenY } = mp.game.graphics.getScreenActiveResolution(0, 0); let rxC = 0.5; let ryC = 0.4; let rWidth = 0.4; let sX = (screenX * 0.1 / 1000); let sY = (screenY * 0.1 / 1000); let eX = sX - 0.1; let eY = sY - 0.1; let sizeMul = 0.08; let yMul = 1.8; var targetPlayerName; let closePos = [0.7125, 0.17] let tradeBoxPos = [0.7125, 0.82] var clickTime; var itemRadial = false; var hoverGrid; var radialSelect = "none"; var clickedItem; let aspectRatioFactor = screenX / screenY; var upRColor = 222; var downRColor = 222; var leftRColor = 222; var rightRColor = 222; var radialDescription; var tradePartner = "Keinem"; var tradePrize = 0; var tradeConfirm = false; var isTrading = false; var isTradingResult = false; var dragTradeItem = null; var inventoryWeight; var items = [[]]; var tradeItems = []; var tradeResultItems = [[]]; var grid = []; grid[0] = [0.3375, 0.205] grid[1] = [0.4195, 0.205] grid[2] = [0.5015, 0.205] grid[3] = [0.5835, 0.205] grid[4] = [0.6655, 0.205] grid[5] = [0.3375, 0.355] grid[6] = [0.4195, 0.355] grid[7] = [0.5015, 0.355] grid[8] = [0.5835, 0.355] grid[9] = [0.6655, 0.355] grid[10] = [0.3375, 0.505] grid[11] = [0.4195, 0.505] grid[12] = [0.5015, 0.505] grid[13] = [0.5835, 0.505] grid[14] = [0.6655, 0.505] grid[15] = [0.3375, 0.655] grid[16] = [0.4195, 0.655] grid[17] = [0.5015, 0.655] grid[18] = [0.5835, 0.655] grid[19] = [0.6655, 0.655] var tradeGrid = []; tradeGrid[0] = [0.3375, 0.925] tradeGrid[1] = [0.4195, 0.925] tradeGrid[2] = [0.5015, 0.925] tradeGrid[3] = [0.5835, 0.925] tradeGrid[4] = [0.6655, 0.925] var mouseLDown = false; var mouseRDown = false; var hoverItem; var dragItem = null; var oldDragSlot; var actFreeSlot; var actFreeTradeSlot; var bufferItem = []; var stackToItem; var stackToTradeItem; mp.events.add("showInventory", (invWeight, itemArr) => { if (show === false) { //mp.gui.chat.activate(false); setInterval() mp.gui.cursor.show(true, true); inventoryWeight = invWeight; items = itemArr; show = true; mp.game.graphics.requestStreamedTextureDict("itemimages", true); } else { mp.events.callRemote('saveInventory', JSON.stringify(items)); mp.gui.chat.activate(true); mp.gui.cursor.show(false, false); show = false; mp.game.graphics.setStreamedTextureDictAsNoLongerNeeded("itemimages"); inventoryWeight = 0; items = null; itemRadial = false; if (tradeItems.length === 0) { isTrading = false; } } }); mp.events.add("openTradeMenu", (tradePartnerName) => { tradePartner = tradePartnerName; isTrading = true; }); mp.events.add("showInventoryToAdmin", (pName, invWeight, itemArr) => { if (showAdmin === false) { targetPlayerName = pName; mp.gui.chat.activate(false); inventoryWeight = invWeight; items = itemArr; mp.game.graphics.requestStreamedTextureDict("itemimages", true); setTimeout(() => mp.gui.cursor.show(true, true), 100); showAdmin = true; } }); mp.events.add("addItem", (item) => { if (show) { items.push(JSON.parse(item)); } }); mp.events.add("clearTradeItems", () => { tradeConfirm = false; tradeItems = [[]]; tradePrize = 0; }); mp.events.add("unlockTradeItems", () => { tradeConfirm = false; }); mp.events.add("showTradeItems", (tradeResultItemArray) => { //for (var i = 0; i < tradeResultItemArray.length; i++) { // tradeItems.push(tradeResultItemArray[i]); //} tradeItems = JSON.parse(tradeResultItemArray); isTrading = true; }); mp.events.add("removeItem", (userItemId, amount) => { if (show) { var arrIndex; for (var i = 0; i < items.length; i++) { if (items[i][5] === userItemId) { arrIndex = i; } } inventoryWeight -= parseInt(items[arrIndex][2]) * amount; items[arrIndex][3] -= amount; if (items[arrIndex][3] === 0) { items.splice(arrIndex, 1); } } }); mp.events.add("render", () => { if (show === true) { var pos = mp.gui.cursor.position; mp.game.graphics.set2dLayer(1); //INVENTARHINTERGRUND mp.game.graphics.drawRect(rxC, ryC, 0.45, 0.7, 255, 255, 255, 200); //inventar mp.game.graphics.set2dLayer(2); //INVENTARÜBERSCHRIFT mp.game.graphics.drawText("Inventar ~g~" + inventoryWeight + "/40000g", [rxC, ryC - (rWidth / 1.20)], { font: 7, color: [112, 128, 144, 254], scale: [0.7, 0.7], outline: true, }); //SLOTS [RECHTECKE] [SLOTZAHLEN] var tempSlot; for (var slots = 0; slots < grid.length; slots++) { mp.game.graphics.drawRect(grid[slots][0], grid[slots][1], sizeMul, sizeMul * yMul, 112, 128, 144, 254); mp.game.graphics.drawText(tempSlot = slots + 1, [grid[slots][0] - (sizeMul / 2) + 0.006, grid[slots][1] - (sizeMul / 2 * yMul)], { font: 7, color: [255, 69, 0, 254], scale: [0.3, 0.3], outline: true, }); } mp.game.graphics.set2dLayer(3); //SPRITES + ITEMANZAHL for (var currentItem = 0; currentItem < items.length; currentItem++) { if (items[currentItem][4] !== "-1") { mp.game.graphics.drawSprite("itemimages", items[currentItem][0].toLowerCase(), grid[parseInt(items[currentItem][4] - 1)][0], grid[parseInt(items[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); mp.game.graphics.drawText("(~y~" + items[currentItem][3] + "~s~)", [grid[parseInt(items[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, grid[parseInt(items[currentItem][4] - 1)][1] + 0.05], { font: 0, color: [255, 255, 255, 255], scale: [0.25, 0.25], outline: true, }); } } mp.game.graphics.set2dLayer(4); //WENN MAUS ÜBER ITEM if (isMouseOverItem(pos[0], pos[1]) && dragItem === null && itemRadial === false) { mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY + 0.055, 0.14, 0.08, 0, 0, 0, 220); var hoverItemP = [items[hoverItem][0], items[hoverItem][1], items[hoverItem][2], items[hoverItem][3]]; //NAME mp.game.graphics.drawText("~g~" + hoverItemP[0], [pos[0] / screenX, pos[1] / screenY + 0.02], { font: 4, color: [255, 255, 255, 255], scale: [0.4, 0.4], outline: true, }); //BESCHREIBUNG mp.game.graphics.drawText(hoverItemP[1], [pos[0] / screenX, pos[1] / screenY + 0.04], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); //EINZELGEWICHT mp.game.graphics.drawText("~y~" + hoverItemP[2] + "g~s~ * " + hoverItemP[3] + "~s~ = ~y~" + hoverItemP[2] * hoverItemP[3] + "g", [pos[0] / screenX, pos[1] / screenY + 0.06], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); } //WENN MOUSE DOWN if (mouseLDown && dragItem !== null || mouseRDown && dragItem !== null) { if (isMouseOverFreeSlot(pos[0], pos[1]) || isMouseOverFreeTradeSlot(pos[0], pos[1]) || isItemOverSameItem(pos[0], pos[1]) || isItemOverSameTradeItem(pos[0], pos[1])) { if (dragTradeItem === false) { mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 100, 255, 100, 255); } else { mp.game.graphics.drawSprite("itemimages", tradeItems[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 100, 255, 100, 255); } } else { if (dragTradeItem === false) { mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 255, 100, 100, 255); } else { mp.game.graphics.drawSprite("itemimages", tradeItems[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 255, 100, 100, 255); } } } mp.game.graphics.set2dLayer(5); if (itemRadial === true) { mp.game.graphics.drawSprite("itemimages", "radialsplit", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 0, 0, 0, 255); mp.game.graphics.drawSprite("itemimages", "radialup", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 222, upRColor, 222, upRColor); mp.game.graphics.drawSprite("itemimages", "radialdown", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 222, downRColor, 222, downRColor); //mp.game.graphics.drawSprite("itemimages", "radialleft", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 222, leftRColor, 222, leftRColor); //mp.game.graphics.drawSprite("itemimages", "radialright", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 222, rightRColor, 222, rightRColor); mp.game.graphics.set2dLayer(6); mp.game.graphics.drawSprite("itemimages", "radialdrop", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 255, 255, 255, 255); mp.game.graphics.drawSprite("itemimages", "radialuse", grid[hoverGrid][0], grid[hoverGrid][1], rWidth / aspectRatioFactor, rWidth, 0, 255, 255, 255, 255); } mp.game.graphics.set2dLayer(7); if (ifMouseSelectRadial(pos[0], pos[1])) { //mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY - 0.02, 0.08, 0.03, 0, 0, 0, 255); mp.game.graphics.drawText("~g~" + radialDescription, [pos[0] / screenX, pos[1] / screenY - 0.033], { font: 4, color: [255, 255, 255, 255], scale: [0.5, 0.5], outline: true, }); } if (isTrading) { mp.game.graphics.set2dLayer(1); mp.game.graphics.drawRect(rxC, 0.925, 0.45, 0.25, 255, 255, 255, 200); mp.game.graphics.set2dLayer(2); var tempSlot2; for (var slots = 0; slots < tradeGrid.length; slots++) { mp.game.graphics.drawRect(tradeGrid[slots][0], tradeGrid[slots][1], sizeMul, sizeMul * yMul, 112, 128, 144, 254); mp.game.graphics.drawText(tempSlot2 = slots + 1, [tradeGrid[slots][0] - (sizeMul / 2) + 0.006, tradeGrid[slots][1] - (sizeMul / 2 * yMul)], { font: 7, color: [69, 255, 0, 254], scale: [0.3, 0.3], outline: true, }); } mp.game.graphics.set2dLayer(3); //SPRITES + ITEMANZAHL if (tradeItems.length !== 0) { for (var currentItem = 0; currentItem < tradeItems.length; currentItem++) { if (tradeItems[currentItem][4] !== "-1") { mp.game.graphics.drawSprite("itemimages", tradeItems[currentItem][0].toLowerCase(), tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); mp.game.graphics.drawText("(~y~" + tradeItems[currentItem][3] + "~s~)", [tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1] + 0.05], { font: 0, color: [255, 255, 255, 255], scale: [0.25, 0.25], outline: true, }); if (tradeConfirm === true) { mp.game.graphics.drawSprite("itemimages", "lock", tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1], rWidth / 8 / 2, rWidth / 5 / 2, 0, 255, 255, 255, 255); } } } } //} else { // if (tradeResultItems.length !== 0) { // for (var currentItem = 0; currentItem < tradeResultItems.length; currentItem++) { // mp.game.graphics.drawSprite("itemimages", tradeResultItems[currentItem][0].toLowerCase(), tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); // mp.game.graphics.drawText("(~y~" + tradeResultItems[currentItem][3] + "~s~)", [tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][1] + 0.05], { // font: 0, // color: [255, 255, 255, 255], // scale: [0.25, 0.25], // outline: true, // }); // } // } //} mp.game.graphics.drawText("Handel mit ~y~" + tradePartner + " ~s~ für ~g~ " + tradePrize + "$", [rxC, 0.81], { font: 7, color: [112, 128, 144, 254], scale: [0.6, 0.6], outline: true, }); mp.game.graphics.set2dLayer(4); if (tradeConfirm === false) { mp.game.graphics.drawSprite("itemimages", "box", tradeBoxPos[0], tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); } else { mp.game.graphics.drawSprite("itemimages", "boxticked", tradeBoxPos[0], tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); } mp.game.graphics.drawSprite("itemimages", "dollar", tradeBoxPos[0] - 0.025, tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); if (isMouseOverTradeDollar(pos[0], pos[1])) { mp.game.graphics.drawText("~g~ Preis festlegen", [pos[0] / screenX, pos[1] / screenY - 0.033], { font: 4, color: [255, 255, 255, 255], scale: [0.5, 0.5], outline: true, }); } if (isMouseOverTradeBox(pos[0], pos[1])) { mp.game.graphics.drawText("~g~Handelsanfrage absenden", [pos[0] / screenX, pos[1] / screenY - 0.033], { font: 4, color: [255, 255, 255, 255], scale: [0.5, 0.5], outline: true, }); } mp.game.graphics.set2dLayer(5); if (isMouseOverTradeItem(pos[0], pos[1]) && dragItem === null && itemRadial === false) { mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY + 0.055, 0.14, 0.08, 0, 0, 0, 220); var hoverItemP = [tradeItems[hoverItem][0], tradeItems[hoverItem][1], tradeItems[hoverItem][2], tradeItems[hoverItem][3]]; //NAME mp.game.graphics.drawText("~g~" + hoverItemP[0], [pos[0] / screenX, pos[1] / screenY + 0.02], { font: 4, color: [255, 255, 255, 255], scale: [0.4, 0.4], outline: true, }); //BESCHREIBUNG mp.game.graphics.drawText(hoverItemP[1], [pos[0] / screenX, pos[1] / screenY + 0.04], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); //EINZELGEWICHT mp.game.graphics.drawText("~y~" + hoverItemP[2] + "g~s~ * " + hoverItemP[3] + "~s~ = ~y~" + hoverItemP[2] * hoverItemP[3] + "g", [pos[0] / screenX, pos[1] / screenY + 0.06], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); } } ////--------------------------------------------------------------DEBUG //mp.game.graphics.drawText(itemRadial.toString() + " ~y~" + radialSelect, [0.5, 0.05], { // font: 7, // color: [255, 0, 0, 255], // scale: [0.7, 0.7], // outline: true, //}); ////KOORDINATEN //mp.game.graphics.drawText((pos[0] / screenX).toFixed(3) + " / " + (pos[1] / screenY).toFixed(3) + " " + tradeItems.length, [pos[0] / screenX, pos[1] / screenY - 0.02], { // font: 4, // color: [255, 255, 255, 255], // scale: [0.4, 0.4], // outline: true, //}); ////----------------------------------------------------------DEBUG END } if (showAdmin === true) { var pos = mp.gui.cursor.position; mp.game.graphics.set2dLayer(1); //INVENTARHINTERGRUND mp.game.graphics.drawRect(rxC, ryC, 0.45, 0.7, 255, 255, 255, 200); mp.game.graphics.set2dLayer(2); //INVENTARÜBERSCHRIFT mp.game.graphics.drawText("Inventar von ~y~" + targetPlayerName + " ~g~" + inventoryWeight + "/40000g", [rxC, ryC - (rWidth / 1.20)], { font: 7, color: [112, 128, 144, 254], scale: [0.7, 0.7], outline: true, }); //SLOTS [RECHTECKE] [SLOTZAHLEN] var tempSlot; for (var slots = 0; slots < grid.length; slots++) { mp.game.graphics.drawRect(grid[slots][0], grid[slots][1], sizeMul, sizeMul * yMul, 112, 128, 144, 254); mp.game.graphics.drawText(tempSlot = slots + 1, [grid[slots][0] - (sizeMul / 2) + 0.006, grid[slots][1] - (sizeMul / 2 * yMul)], { font: 7, color: [255, 69, 0, 254], scale: [0.3, 0.3], outline: true, }); } mp.game.graphics.set2dLayer(3); //SPRITES + ITEMANZAHL for (var currentItem = 0; currentItem < items.length; currentItem++) { if (items[currentItem][4] !== "-1") { mp.game.graphics.drawSprite("itemimages", items[currentItem][0].toLowerCase(), grid[parseInt(items[currentItem][4] - 1)][0], grid[parseInt(items[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); mp.game.graphics.drawText("(~y~" + items[currentItem][3] + "~s~)", [grid[parseInt(items[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, grid[parseInt(items[currentItem][4] - 1)][1] + 0.05], { font: 0, color: [255, 255, 255, 255], scale: [0.25, 0.25], outline: true, }); } } mp.game.graphics.set2dLayer(4); //WENN MAUS ÜBER ITEM if (isMouseOverItem(pos[0], pos[1]) && dragItem === null && itemRadial === false) { mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY + 0.055, 0.14, 0.08, 0, 0, 0, 220); var hoverItemP = [items[hoverItem][0], items[hoverItem][1], items[hoverItem][2], items[hoverItem][3]]; //NAME mp.game.graphics.drawText("~g~" + hoverItemP[0], [pos[0] / screenX, pos[1] / screenY + 0.02], { font: 4, color: [255, 255, 255, 255], scale: [0.4, 0.4], outline: true, }); //BESCHREIBUNG mp.game.graphics.drawText(hoverItemP[1], [pos[0] / screenX, pos[1] / screenY + 0.04], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); //EINZELGEWICHT mp.game.graphics.drawText("~y~" + hoverItemP[2] + "g~s~ * " + hoverItemP[3] + "~s~ = ~y~" + hoverItemP[2] * hoverItemP[3] + "g", [pos[0] / screenX, pos[1] / screenY + 0.06], { font: 4, color: [255, 255, 255, 255], scale: [0.35, 0.35], outline: true, }); } if (isMouseOverX(pos[0], pos[1])) { mp.game.graphics.drawSprite("itemimages", "x", closePos[0], closePos[1], 0.02, 0.035, 0, 220, 20, 60, 255); } else { mp.game.graphics.drawSprite("itemimages", "x", closePos[0], closePos[1], 0.02, 0.035, 0, 255, 255, 255, 255); } } }); function isMouseOverItem(cX, cY) { if (dragItem === null) { var x = cX / screenX; var y = cY / screenY; var a; var b; var c; for (var s = 0; s < 20; s++) { a = grid[s][0] - x; b = grid[s][1] - y; c = Math.sqrt(a * a + b * b); var invSlot = (s + 1); if (c < sizeMul / 2) { for (i = 0; i < items.length; i++) { if (parseInt(items[i][4]) === invSlot) { hoverItem = i; return true; } } } } } else { if (itemRadial === false) { var x = cX / screenX; var y = cY / screenY; var a; var b; var c; for (var s = 0; s < 20; s++) { a = grid[s][0] - x; b = grid[s][1] - y; c = Math.sqrt(a * a + b * b); var invSlot = (s + 1); if (c < sizeMul / 2) { for (i = 0; i < items.length; i++) { if (parseInt(items[i][4]) === invSlot) { hoverGrid = s; return true; } } } } } } } function isMouseOverTradeItem(cX, cY) { if (dragItem === null && isTrading) { var x = cX / screenX; var y = cY / screenY; var a; var b; var c; for (var s = 0; s < 5; s++) { a = tradeGrid[s][0] - x; b = tradeGrid[s][1] - y; c = Math.sqrt(a * a + b * b); var invSlot = (s + 1); if (c < sizeMul / 2) { for (i = 0; i < tradeItems.length; i++) { if (parseInt(tradeItems[i][4]) === invSlot) { hoverItem = i; return true; } } } } } } function isMouseOverFreeSlot(cX2, cY2) { var x = cX2 / screenX; var y = cY2 / screenY; var isItemOnSlot = 0; for (var s = 0; s < 20; s++) { var invSlot = (s + 1); if (x > grid[s][0] - sizeMul / 2 && x < grid[s][0] + sizeMul / 2 && y > grid[s][1] - sizeMul / 2 * aspectRatioFactor && y < grid[s][1] + sizeMul / 2 * aspectRatioFactor) { for (i = 0; i < items.length; i++) { if (parseInt(items[i][4]) === invSlot) { isItemOnSlot++; } } if (isItemOnSlot === 0) { actFreeSlot = s + 1; return true; } } } } function isMouseOverFreeTradeSlot(cX2, cY2) { if (tradeConfirm === false) { var x = cX2 / screenX; var y = cY2 / screenY; var isItemOnSlot = 0; for (var s = 0; s < 5; s++) { var invSlot = (s + 1); if (x > tradeGrid[s][0] - sizeMul / 2 && x < tradeGrid[s][0] + sizeMul / 2 && y > tradeGrid[s][1] - sizeMul / 2 * aspectRatioFactor && y < tradeGrid[s][1] + sizeMul / 2 * aspectRatioFactor) { for (i = 0; i < tradeItems.length; i++) { if (parseInt(tradeItems[i][4]) === invSlot) { isItemOnSlot++; } } if (isItemOnSlot === 0) { actFreeTradeSlot = s + 1; return true; } } } } } function isItemOverSameItem(cX2, cY2) { if (dragItem !== null && items.length > 0) { var x = cX2 / screenX; var y = cY2 / screenY; for (var s = 0; s < 20; s++) { var invSlot = (s + 1); if (x > grid[s][0] - sizeMul / 2 && x < grid[s][0] + sizeMul / 2 && y > grid[s][1] - sizeMul / 2 * aspectRatioFactor && y < grid[s][1] + sizeMul / 2 * aspectRatioFactor) { for (i = 0; i < items.length; i++) { if (dragTradeItem === false) { if (items[dragItem][0] === items[i][0] && parseInt(items[i][4]) === invSlot && items[hoverItem][4] !== items[i][4]) { stackToItem = i; return true; } } else { if (tradeItems[dragItem][0] === items[i][0] && parseInt(items[i][4]) === invSlot) { stackToItem = i; return true; } } } } } } } function isItemOverSameTradeItem(cX2, cY2) { if (dragItem !== null && tradeItems.length > 0) { var x = cX2 / screenX; var y = cY2 / screenY; for (var s = 0; s < 5; s++) { var invSlot = (s + 1); if (x > tradeGrid[s][0] - sizeMul / 2 && x < tradeGrid[s][0] + sizeMul / 2 && y > tradeGrid[s][1] - sizeMul / 2 * aspectRatioFactor && y < tradeGrid[s][1] + sizeMul / 2 * aspectRatioFactor) { for (i = 0; i < tradeItems.length; i++) { if (dragTradeItem === false) { if (items[dragItem][0] === tradeItems[i][0] && parseInt(tradeItems[i][4]) === invSlot) { stackToTradeItem = i; return true; } } else { if (tradeItems[dragItem][0] === tradeItems[i][0] && parseInt(tradeItems[i][4]) === invSlot && tradeItems[hoverItem][4] !== tradeItems[i][4]) { stackToTradeItem = i; return true; } } } } } } } function isMouseOverX(cX2, cY2) { if (showAdmin) { var x = cX2 / screenX; var y = cY2 / screenY; if (x > closePos[0] - 0.01 && x < closePos[0] + 0.01 && y > closePos[1] - 0.0175 && y < closePos[1] + 0.0175) { return true; } } } function isMouseOverTradeBox(cX2, cY2) { if (show && tradeConfirm === false) { var x = cX2 / screenX; var y = cY2 / screenY; if (x > tradeBoxPos[0] - 0.01 && x < tradeBoxPos[0] + 0.01 && y > tradeBoxPos[1] - 0.0175 && y < tradeBoxPos[1] + 0.0175) { return true; } } } function isMouseOverTradeDollar(cX2, cY2) { if (show && tradeConfirm === false) { var x = cX2 / screenX; var y = cY2 / screenY; if (x > (tradeBoxPos[0] - 0.025) - 0.01 && x < (tradeBoxPos[0] - 0.025) + 0.01 && y > tradeBoxPos[1] - 0.0175 && y < tradeBoxPos[1] + 0.0175) { return true; } } } function ifMouseSelectRadial(cX2, cY2) { if (show && itemRadial === true) { var x = cX2 / screenX; var y = cY2 / screenY; var a; var b; var c; //OBEN if (x > grid[hoverGrid][0] - 0.0255 / aspectRatioFactor && x < grid[hoverGrid][0] + 0.0255 / aspectRatioFactor && y < grid[hoverGrid][1] - 0.065 && y > grid[hoverGrid][1] - 0.2) { radialSelect = "up"; radialDescription = "Wegwerfen"; upRColor = 255; return true; } //UNTEN else if (x > grid[hoverGrid][0] - 0.0255 / aspectRatioFactor && x < grid[hoverGrid][0] + 0.0255 / aspectRatioFactor && y > grid[hoverGrid][1] + 0.065 && y < grid[hoverGrid][1] + 0.2) { radialSelect = "down"; radialDescription = "Benutzen / Essen"; downRColor = 255; return true; } ////LINKS //else if (x > grid[hoverGrid][0] - 0.2 / aspectRatioFactor && x < grid[hoverGrid][0] - 0.065 / aspectRatioFactor && y < grid[hoverGrid][1] + 0.0255 && y > grid[hoverGrid][1] - 0.0255) { // radialSelect = "left"; // leftRColor = 255; // return true; //} ////RECHTS //else if (x < grid[hoverGrid][0] + 0.2 / aspectRatioFactor && x > grid[hoverGrid][0] + 0.065 / aspectRatioFactor && y < grid[hoverGrid][1] + 0.0255 && y > grid[hoverGrid][1] - 0.0255) { // radialSelect = "right"; // rightRColor = 255; // return true; else { upRColor = 222; downRColor = 222; leftRColor = 222; rightRColor = 222; } } } mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, worldPosition, hitEntity) => { var cX = x / screenX; var cY = y / screenY; if (show) { //LINKE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "left" && mouseLDown === false && mouseRDown === false) { if (isTrading && isMouseOverTradeBox(x, y) && tradePrize > 0) { tradeConfirm = true; mp.events.callRemote('sendTradeItemsToPartner', JSON.stringify(tradeItems), tradePrize, tradePartner); } if (isTrading && isMouseOverTradeDollar(x, y)) { var tradeMoney = new InputHelper("Wie viel $ möchtest du für deine Items haben?"); tradeMoney.show(); tradeMoney.getValue((data) => { var amount = parseInt(data); if (isNaN(amount) || amount < 0) { mp.game.graphics.notify('~r~Du musst eine Zahl größer als 0 eingeben!'); return; } tradePrize = amount; }) } mouseLDown = true; if (isMouseOverItem(x, y) && dragItem === null && itemRadial === false) { dragItem = hoverItem; oldDragSlot = items[dragItem][4]; items[dragItem][4] = "-1"; dragTradeItem = false; } else if (ifMouseSelectRadial(x, y)) { switch (radialSelect) { case "up": var dropInput = new InputHelper("Wie viel Items möchtest du wegwerfen?"); dropInput.show(); dropInput.getValue((data) => { var amount = parseInt(data); if (isNaN(amount) || amount < 1) { mp.game.graphics.notify('~r~Du musst eine Zahl größer als 0 eingeben!'); return; } else if (parseInt(amount) > parseInt(items[clickedItem][3])) { mp.game.graphics.notify('~r~So viele Items hast du nicht!'); return; } mp.events.callRemote('itemInteract', "drop", items[clickedItem][5], parseInt(amount)); }); itemRadial = false; break; case "down": mp.events.callRemote('itemInteract', "use", items[clickedItem][5], 1); itemRadial = false; break; case "left": itemRadial = false; break; case "right": itemRadial = false; break; } } else if (isMouseOverTradeItem(x, y) && dragItem === null && itemRadial === false && tradeConfirm === false) { dragItem = hoverItem; oldDragSlot = tradeItems[dragItem][4]; tradeItems[dragItem][4] = "-1"; dragTradeItem = true; } } //HOCH if (upOrDown === "up" && leftOrRight === "left" && mouseLDown === true && itemRadial === false) { mouseLDown = false; if (dragItem !== null) { if (isMouseOverFreeSlot(x, y)) { if (dragTradeItem === false) { items[dragItem][4] = actFreeSlot; } else { items.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], tradeItems[dragItem][3], actFreeSlot.toString(), tradeItems[dragItem][5]]); tradeItems.splice(dragItem, 1); } oldDragSlot = null; dragItem = null; hoverItem = null; } else if (isItemOverSameItem(x, y)) { if (dragTradeItem === false) { var newAmount = parseInt(items[stackToItem][3]) + parseInt(items[dragItem][3]); items[stackToItem][3] = newAmount.toString(); items[dragItem][4] = "-1"; } else { var newAmount = parseInt(items[stackToItem][3]) + parseInt(tradeItems[dragItem][3]); items[stackToItem][3] = newAmount.toString(); tradeItems.splice(dragItem,1); } dragItem = null; hoverItem = null; } else if (isItemOverSameTradeItem(x, y)) { if (dragTradeItem === false) { var newAmount = parseInt(tradeItems[stackToTradeItem][3]) + parseInt(items[dragItem][3]); tradeItems[stackToTradeItem][3] = newAmount.toString(); items[dragItem][4] = "-1"; } else { var newAmount = parseInt(tradeItems[stackToTradeItem][3]) + parseInt(tradeItems[dragItem][3]); tradeItems[stackToTradeItem][3] = newAmount.toString(); tradeItems[dragItem][4] = "-1"; } dragItem = null; hoverItem = null; } else if (isMouseOverFreeTradeSlot(x, y)) { if (dragTradeItem === false) { tradeItems.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], items[dragItem][3], actFreeTradeSlot.toString(), items[dragItem][5]]); items.splice(dragItem, 1); } else { tradeItems[dragItem][4] = actFreeTradeSlot; } oldDragSlot = null; dragItem = null; hoverItem = null; } else { if (dragTradeItem === false) { items[dragItem][4] = oldDragSlot; } else { tradeItems[dragItem][4] = oldDragSlot; } dragItem = null; hoverItem = null; } } } //RECHTE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "right" && mouseLDown === false && mouseRDown === false && itemRadial === false) { clickTime = Date.now(); mouseRDown = true; if (isMouseOverItem(x, y) && dragItem === null) { dragItem = hoverItem; oldDragSlot = items[hoverItem][4]; bufferItem = [items[hoverItem][0], items[hoverItem][1], items[hoverItem][2], items[hoverItem][3], items[hoverItem][4], items[hoverItem][5]]; items[hoverItem][3]--; dragTradeItem = false; } else if (isMouseOverTradeItem(x, y) && dragItem === null && tradeConfirm === false) { dragItem = hoverItem; oldDragSlot = tradeItems[hoverItem][4]; bufferItem = [tradeItems[hoverItem][0], tradeItems[hoverItem][1], tradeItems[hoverItem][2], tradeItems[hoverItem][3], tradeItems[hoverItem][4], tradeItems[hoverItem][5]]; tradeItems[hoverItem][3]--; dragTradeItem = true; } } //HOCH if (upOrDown === "up" && leftOrRight === "right" && mouseRDown === true && itemRadial === false) { mouseRDown = false; if (Date.now() - clickTime < 100 && isMouseOverItem(x, y)) { clickedItem = hoverItem; items[hoverItem][3]++; itemRadial = true; hoverItem = null; dragItem = null; clickTime = null; } else { if (dragItem !== null) { if (isMouseOverFreeSlot(x, y)) { if (dragTradeItem === false) { items.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], "1", actFreeSlot.toString(), "-1"]); if (items[hoverItem][3] === 0) { items[hoverItem][4] = "-1"; } } else { items.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], "1", actFreeSlot.toString(), "-1"]); if (tradeItems[hoverItem][3] === 0) { tradeItems.splice(hoverItem, 1); } } dragItem = null; hoverItem = null; } else if (isItemOverSameItem(x, y)) { items[stackToItem][3]++; if (dragTradeItem === false) { if (items[hoverItem][3] === 0) { items[hoverItem][4] = "-1"; } } else { if (tradeItems[hoverItem][3] === 0) { tradeItems.splice(hoverItem, 1); } } bufferItem = null; dragItem = null; hoverItem = null; } else if (isItemOverSameTradeItem(x, y)) { tradeItems[stackToTradeItem][3]++; if (dragTradeItem === false) { if (items[hoverItem][3] === 0) { items[hoverItem][4] = "-1"; } } else { if (tradeItems[hoverItem][3] === 0) { tradeItems[hoverItem][4] = "-1"; } } bufferItem = null; dragItem = null; hoverItem = null; } else if (isMouseOverFreeTradeSlot(x, y)) { if (dragTradeItem === false) { tradeItems.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], "1", actFreeTradeSlot.toString(), "-1"]); if (items[hoverItem][3] === 0) { items[hoverItem][4] = "-1"; } } else { tradeItems.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], "1", actFreeTradeSlot.toString(), "-1"]); if (tradeItems[hoverItem][3] === 0) { tradeItems[hoverItem][4] = "-1"; } } dragItem = null; hoverItem = null; } else { if (dragTradeItem === false) { items[hoverItem][3]++; } else { tradeItems[hoverItem][3]++; } bufferItem = null; dragItem = null; hoverItem = null; } } } } } if (showAdmin) { //LINKE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "left" && mouseLDown === false && mouseRDown === false) { if (isMouseOverItem(x, y)) { items[hoverItem][4] = "-1" inventoryWeight -= parseInt(items[hoverItem][2]) * parseInt(items[hoverItem][3]); mp.events.callRemote('removeItemAsAdmin', "stack", items[hoverItem][5], targetPlayerName); } } //RECHTE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "right" && mouseLDown === false && mouseRDown === false) { if (isMouseOverItem(x, y)) { items[hoverItem][3]--; mp.events.callRemote('removeItemAsAdmin', "one", items[hoverItem][5], targetPlayerName); if (items[hoverItem][3] === 0) { items[hoverItem][4] = "-1"; } inventoryWeight -= items[hoverItem][2]; } } if (upOrDown === "down" && leftOrRight === "left" && mouseLDown === false && mouseRDown === false) { if (isMouseOverX(x, y)) { mp.gui.chat.activate(true); mp.gui.cursor.show(false, false); showAdmin = false; mp.game.graphics.setStreamedTextureDictAsNoLongerNeeded("itemimages"); inventoryWeight = 0; items = null; } } } });