So I'm working on a game at the movement and I've implemented a zoom feature so the player can choose between 8, 16 and 32 for the map's icon-size variable.
The problem is that when they're at 8, a view of 35 is not enough to fit the whole screen which is really annoying and I can't think of a work around. What is going on and how can I fix this? Thank you.
P.S Yes I like to push mechanics to their limits but this is actually well within reason to ask for 50 at least. Or more cool would be to just take off the cap.
1
2
ID:260963
Aug 25 2011, 7:15 pm (Edited on Aug 25 2011, 7:21 pm)
|
|
Aug 25 2011, 7:33 pm
|
|
The only work around I can think of, is screen objects. However I'm not sure if their limits allow that much distance.
|
In response to Zaoshi
|
|
What do you mean?
|
In response to Kyle_ZX
|
|
You could add tiles, which are outside range of 35, to client.screen at proper location, it'll look like map. However this is horrible work around for multiplayer game.
|
In response to Zaoshi
|
|
Like for(turf in oview(100)), client.screen += turf?
I know that's not the code, but that method? |
In response to Kyle_ZX
|
|
Well since it already supports view of 35, you'll need to add only things outside that range.
for(var/turf/T in (view(40) - view(35))) // not sure if subtraction works here However, this will NOT work in multiplayer game. If you need this in multiplayer you'll have to copy atoms either create images. (same object cannot have two different screen_loc for different players) |
In response to Zaoshi
|
|
I'm getting a lot of errors with that and I can't seem to fix it. Please try compile one?
|
In response to Kyle_ZX
|
|
Turfs don't seem to have screen_loc variable.
Forget all this... It's not only slow, but also has same limit of view(35) =/ mob/verb/test() |
In response to Zaoshi
|
|
Sorry for double post.
I just remembered there's block() proc: mob/verb/test() However it look like a minute to complete. |
In response to Zaoshi
|
|
I added this and run it but it crashed my game. Did it work for you?
|
In response to Kyle_ZX
|
|
Yes, it did work.
|
In response to Zaoshi
|
|
Okay well I tried the code from both posts, just copy pasting and running them as a command from in the game and both caused it to crash.
Thanks for trying to help but it just doesn't work. |
In response to Zaoshi
|
|
Actually I tried it again and waited for about 20 seconds and it did something, didn't work though. It was like it had copied a chunk of the map and moved it northwest-ward. Bizzare stuff. Just so you know I need this to be constant so the player always sees 50 view. This means it can't have any visible delay.
|
In response to Kyle_ZX
|
|
That's strange, it doesn't crash for me. But true, it's not suitable for realtime.
|
In response to Zaoshi
|
|
Okay, seeing as I was talking about client & world view I thought you understood.
|
In response to Complex Robot
|
|
I guess but I'd really like someone such as Lummox to point me in the right direction.
|
In response to Kyle_ZX
|
|
A feature request would probably get a faster response than this forum thread.
|
In response to Complex Robot
|
|
Yea but I also wanted others to see this and maybe get told how I can work around it.
|
In response to Kyle_ZX
|
|
You can link to the feature request and people can post comments on it there.
Anyways, I'm not really helping, but I don't think there's a workaround. (client.screen won't pan smoothly, and runs pretty slow if it's updated often.) |
1
2