Flower ☠ Power Posted April 21, 2020 Share Posted April 21, 2020 I'm trying to make a custom F11 map but when I zoom in my blips get screwed up because I cannot guess the right formula to calculate their position in the screen when zoomed in. local fullMapZoom = 1 local xfullMapOffset = 0 local yfullMapOffset = 0 function renderFullMap() dxSetRenderTarget(fullMapRender, true) dxDrawImage((dxD_fullMapRT[3]/2) - (dxD_fullMapRT[3]/2) * fullMapZoom + xfullMapOffset, (dxD_fullMapRT[4]/2) - (dxD_fullMapRT[4]/2) * fullMapZoom + yfullMapOffset, dxD_fullMapRT[3] * fullMapZoom, dxD_fullMapRT[4] * fullMapZoom, radar_full, 0, 0, 0, -1, false) --Render the big map for _, v in pairs(nearbyPlayers) do --Loop in a table of players if (v[6] == myDim) then local x, y = getElementPosition(v[1]) -- Players x, y local blipX, blipY = (x + 3000) * (dxD_fullMapRT[3]/6000), (y - 3000) * (-dxD_fullMapRT[4]/6000) local blipX = blipX + (blipX - blipX*fullMapZoom)/2 + xfullMapOffset local blipY = blipY + (blipY - blipY*fullMapZoom)/2 + yfullMapOffset dxDrawImage(blipX - radar_icons[1][2], blipY - radar_icons[1][3], radar_icons[1][4], radar_icons[1][5], radar_icons[1][1], 0, 0, 0, v[5]) end end dxSetRenderTarget() dxDrawImage(dxD_fullMapRT[1], dxD_fullMapRT[2], dxD_fullMapRT[3], dxD_fullMapRT[4], fullMapRender, 0, 0, 0, -1, false) end Look at the small white icon in the map and then when zoomed in it's displaced and I'm really struggling to get the formula to calculate the position on the screen after zoomed in, please help me. Link to comment
Master_MTA Posted April 22, 2020 Share Posted April 22, 2020 On 21/04/2020 at 22:45, Flower ☠ Power said: zoomed Expand display ur click zoom in btn code Link to comment
Flower ☠ Power Posted April 22, 2020 Author Share Posted April 22, 2020 On 22/04/2020 at 03:42, Master_MTA said: display ur click zoom in btn code Expand That really doesn't matter but here it is local zoomSensitivity = 0.05 function zoomFullMap(button, press) if (button == 'mouse_wheel_up') and (press == true) then fullMapZoom = fullMapZoom + zoomSensitivity elseif (button == 'mouse_wheel_down') and (press == true) then fullMapZoom = fullMapZoom - zoomSensitivity end end addEventHandler("onClientKey", root, zoomFullMap) It just adds or subtracks 0.05 to the fullMapZoom variable depending you scroll down/up, if you want the formula used to zoom in/out the map look at this: dxDrawImage((dxD_fullMapRT[3]/2) - (dxD_fullMapRT[3]/2) * fullMapZoom + xfullMapOffset, (dxD_fullMapRT[4]/2) - (dxD_fullMapRT[4]/2) * fullMapZoom + yfullMapOffset, dxD_fullMapRT[3] * fullMapZoom, dxD_fullMapRT[4] * fullMapZoom, radar_full, 0, 0, 0, -1, false) --Render the big map I just center the map image multiply by the amount of zoom then add offset to move the map Link to comment
Master_MTA Posted April 23, 2020 Share Posted April 23, 2020 On 21/04/2020 at 22:45, Flower ☠ Power said: dxDrawImage((dxD_fullMapRT[3]/2) - (dxD_fullMapRT[3]/2) * fullMapZoom + xfullMapOffset, (dxD_fullMapRT[4]/2) - (dxD_fullMapRT[4]/2) * fullMapZoom + yfullMapOffset, dxD_fullMapRT[3] * fullMapZoom, dxD_fullMapRT[4] * fullMapZoom, radar_full, 0, 0, 0, -1, false) --Render the big map Expand i need u to declare each parameter of this so am being able to help u Link to comment
Flower ☠ Power Posted April 24, 2020 Author Share Posted April 24, 2020 On 23/04/2020 at 23:31, Master_MTA said: i need u to declare each parameter of this so am being able to help u Expand dxD_fullMapRT = {screenW * 0.2677, screenH * 0.0870, screenW * 0.4646, screenH * 0.8259} This are just numbers the first two are x, y positions of where the render target must be in the the screen, then the other two are the size of the render target width and height respectively, all in relative numbers, if u want the exact number well just do the math: 1920 * 0.4646 ~= 892 Link to comment
Master_MTA Posted April 24, 2020 Share Posted April 24, 2020 (edited) On 24/04/2020 at 10:52, Flower ☠ Power said: math Expand actually i don't understand what did u do in the drawing method so i will suppose my x,y,width,height and u can replace it later local mapPath = "image.png" local blipPath = "blip.png" local scx,scy = guiGetScreenSize() local width = 500 local height = 500 local x=( scx/2 ) - (width/2) local y=( scy/2 ) - (height/2) local blipWidth = 32 local blipHeight = 32 --let's start with the zoom in variables local zoomSensitivity = 1-- each scroll will zoom in 20 px of width and 10px of height local fullMapZoom = 0 function zoomFullMap(button, press) if (button == 'mouse_wheel_up') and (press == true) then fullMapZoom = fullMapZoom + zoomSensitivity elseif (button == 'mouse_wheel_down') and (press == true) then fullMapZoom = fullMapZoom - zoomSensitivity end end addEventHandler("onClientKey", root, zoomFullMap) addEventHandler("onClientRender", root, function() if fullMapZoom > 0 then dxDrawImageSection(x,y,width,height, fullMapZoom*10, fullMapZoom*5, width - (fullMapZoom*10), height - (fullMapZoom*5), imagePath) --now we done dealing with image so let's start work on blip am gonna do it for local player and u can do it for all players local worldPos = {getElementPosition(localPlayer)} local pos = {getScreenFromWorldPosition(unpack(worldPos))} local ratio = {(pos[1]/scx)*100,(pos[2]/scy)*100} local fPos = {ratio[1]*width,ratio[2]*height} dxDrawImage(x+fPos[1]-(fullMapZoom*10*2),y+fPos[2]-(fullMapZoom*5*2),blipWidth,blipHeight, blipPath, 0, 0, 0, -1, true) else dxDrawImage(x,y,width,height, imagePath, 0, 0, 0, -1, false) --now we done dealing with image so let's start work on blip am gonna do it for local player and u can do it for all players local worldPos = {getElementPosition(localPlayer)} local pos = {getScreenFromWorldPosition(unpack(worldPos))} local ratio = {(pos[1]/scx)*100,(pos[2]/scy)*100} local fPos = {ratio[1]*width,ratio[2]*height} dxDrawImage(x+fPos[1],y+fPos[2],blipWidth,blipHeight, blipPath, 0, 0, 0, -1, true) end end) try this am actually don't know if it's gonna work or not but test it and if there is any mistakes please post photo Edited April 24, 2020 by Master_MTA Link to comment
Flower ☠ Power Posted April 24, 2020 Author Share Posted April 24, 2020 On 24/04/2020 at 22:30, Master_MTA said: actually i don't understand what did u do in the drawing method so i will suppose my x,y,width,height and u can replace it later local mapPath = "image.png" local blipPath = "blip.png" local scx,scy = guiGetScreenSize() local width = 500 local height = 500 local x=( scx/2 ) - (width/2) local y=( scy/2 ) - (height/2) local blipWidth = 32 local blipHeight = 32 --let's start with the zoom in variables local zoomSensitivity = 1-- each scroll will zoom in 20 px of width and 10px of height local fullMapZoom = 0 function zoomFullMap(button, press) if (button == 'mouse_wheel_up') and (press == true) then fullMapZoom = fullMapZoom + zoomSensitivity elseif (button == 'mouse_wheel_down') and (press == true) then fullMapZoom = fullMapZoom - zoomSensitivity end end addEventHandler("onClientKey", root, zoomFullMap) addEventHandler("onClientRender", root, function() if fullMapZoom > 0 then dxDrawImageSection(x,y,width,height, fullMapZoom*10, fullMapZoom*5, width - (fullMapZoom*10), height - (fullMapZoom*5), imagePath) --now we done dealing with image so let's start work on blip am gonna do it for local player and u can do it for all players local worldPos = {getElementPosition(localPlayer)} local pos = {getScreenFromWorldPosition(unpack(worldPos))} local ratio = {(pos[1]/scx)*100,(pos[2]/scy)*100} local fPos = {ratio[1]*width,ratio[2]*height} dxDrawImage(x+fPos[1]-(fullMapZoom*10*2),y+fPos[2]-(fullMapZoom*5*2),blipWidth,blipHeight, blipPath, 0, 0, 0, -1, true) else dxDrawImage(x,y,width,height, imagePath, 0, 0, 0, -1, false) --now we done dealing with image so let's start work on blip am gonna do it for local player and u can do it for all players local worldPos = {getElementPosition(localPlayer)} local pos = {getScreenFromWorldPosition(unpack(worldPos))} local ratio = {(pos[1]/scx)*100,(pos[2]/scy)*100} local fPos = {ratio[1]*width,ratio[2]*height} dxDrawImage(x+fPos[1],y+fPos[2],blipWidth,blipHeight, blipPath, 0, 0, 0, -1, true) end end) try this am actually don't know if it's gonna work or not but test it and if there is any mistakes please post photo Expand I am so sorry for making you waste your time I figured it out right now and by right now I mean right now at this moment. local x, y = getElementPosition(v[1]) local blipX, blipY = (x + 3000) * (dxD_fullMapRT[3] * fullMapZoom/6000), (y - 3000) * ((-dxD_fullMapRT[4]*fullMapZoom)/6000) local blipX = blipX + (dxD_fullMapRT[3]/2) - (dxD_fullMapRT[3]/2 * fullMapZoom) + xfullMapOffset local blipY = blipY + (dxD_fullMapRT[4]/2) - (dxD_fullMapRT[4]/2 * fullMapZoom) + yfullMapOffset dxDrawImage(blipX - radar_icons[1][2], blipY - radar_icons[1][3], radar_icons[1][4], radar_icons[1][5], radar_icons[1][1], 0, 0, 0, v[5]) This is the correct way to calculate it, the reason why it wasn't working it was because when I was dividing the map width with 6000 I wasn't taking into account that when zoomed in it has to be multiplied with the zoom factor, and then after that it's just adding the same amount of X or Y added in the previously in the zoomed map. I have really thank you for your time and effort you spent trying to help me I really apreciate, thanks buddy. Link to comment
Master_MTA Posted April 24, 2020 Share Posted April 24, 2020 On 24/04/2020 at 23:01, Flower ☠ Power said: thanks Expand ur welcome friend happy to help u Link to comment
mathewzika Posted July 13, 2021 Share Posted July 13, 2021 (edited) Can you give me the map PNG/JPG Image file please? maybe it is HD? Edit: if anyone have any link or F11 Map Images / PNG/JPG can give me IT? i wanna use some new maps FOR F11, thanks! Ik this is an old topic. Edited July 13, 2021 by mathewzika Link to comment
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now