Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AD_1296: Removing previous change and adding support for parameter ta… #1297

Merged
merged 12 commits into from
Nov 30, 2017

Conversation

ShaneWalsh
Copy link
Collaborator

AD_1296: Removing previous change and adding support for parameter targeting highlighting. By default now all query hexes always highlights the selected hexs by default. Only creature movement sets it to false, so you get the dark path. Selecting a choice path, like Grumble's Boom Box will not highlight the entire path as specified in 1296, and so should any other ability using the same targeting method queryChoice.

updateDisplay was being abused, and was being called everywhere and now it should only be called by queryHexes() and die(). It shouldn't be abused as it was, it made it very hard to keep the UI in a consistent state. Hexegons should be controlling cleaning the display. Now whenever a hex needs to be changed, cleanHex should be called instead to clean only that hex and then apply the changes directly to it, instead of clearing the entire screen.

I think this should resolve #1296 #1295 #1294 and some other stuff.

I have changed alot of code here, especially how things work by default. But its in an effort to get some more consistency across how hexagons works. It will probably break a few abilities, let me know if it does, and why it does and I can try and change them.

If your pull request tries to address a specific issue from the repository, please reference to it.
Don't forget to include a description of the changes proposes. https://discord.me/AncientBeast

ShaneWalsh and others added 6 commits November 27, 2017 20:11
…rgeting highlighting. By default now all query hexes always highlights the selected hexs by default. Only creature movement sets it to false, so you get the dark path. Selecting a choice path, like Grumble's Boom Box will not highlight the entire path as specified in 1296, and so should any other ability using the same targeting method queryChoice.

updateDisplay was being abused, and was being called everywhere. It shouldn't be. Hexegons should be controlling cleaning the display. Now whenever a hex needs to be changed, cleanHex should be called instead to clean only that hex and then apply the changes directly to it, instead of clearing the entire screen.
@@ -823,11 +834,16 @@ var HexGrid = class HexGrid {
this.showCreaturehexes();
}

cleanHex (hex) {
hex.cleanDisplayVisualState()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Any punctuation required after this?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ES6 does not require punctuation, but in order for it to be backwards compatible with older browsers without transpiling it should have one. So I will add it in my next few changes.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To clarify, Javascript inherently supports no trailing semi-colons through ASI (Automatic Semi-colon Insertion) and this has nothing to do with old browsers (it is part of the original code base).

However, always using semi-colons is a good thing, because if files are concatenated, you never know the state of other libs that might get concatenated with your code. This is why in the mid 2000's and sometimes still today you can find open source libs that prefix all JS files with a leading semi-colon for no apparent reason... It's to fix the lack of semi-colon when concatenating multiple JS sources. Trailing semi-colons are a good practice and should not be neglected ;)

@DreadKnight DreadKnight temporarily deployed to ancientbeast-pr-1297 November 27, 2017 20:46 Inactive
@DreadKnight
Copy link
Member

@ShaneWalsh Nice work so far! Definitely more consistent, still need to do more testing.
One regression so far, the cancel hexagon is missing when hovering non viable targets, #847

@DreadKnight
Copy link
Member

A small visual issue here: it would be ideal if the hexagon under red player's Swine Thug would be rendered above the blue outlined ones so that it wouldn't get a bit overlapped at the bottom side.

screenshot from 2017-11-27 23-07-15

@DreadKnight
Copy link
Member

The hexagons under active medium and large units tend to glitch a bit if hovering on the units themselves while no ability is selected.

Scavenger's Escort Service is a bit glitchy when targeting, as it should display both the Scavenger's hexagons and the target's when picking a new location.

Abolished's Greater Pyre should highlight all nearby hexagons as it's an AoE ability (old issue) #882

@ShaneWalsh
Copy link
Collaborator Author

I pushed changes that should resolve #882 and #847 .

Can you clarify "The hexagons under active medium and large units tend to glitch a bit if hovering on the units themselves while no ability is selected." Is this not just the new position of the unit being indicated by flashing? because when they are out of moves there is no change in the hex on hovering. Can you give me a screenshot of what you want to change, and what you want it to do instead :D

In the mean time I will look at adding the missed punctuation and ill look at the Scavenger's escort.

@ShaneWalsh
Copy link
Collaborator Author

Added fix for Scavenger's Escort Service. It should now highlight all of the final position hexes. Added punctuation.

@DreadKnight DreadKnight temporarily deployed to ancientbeast-pr-1297 November 28, 2017 20:43 Inactive
@DreadKnight
Copy link
Member

DreadKnight commented Nov 28, 2017

Tested, nice work! Regarding remaining issue: when moving the unit, the initial location hexagons under the unit shouldn't get overlapped by the "walk path" ones (except in the case of Scavenger's Escort Service, since that's an ability and that kind of overlap behaviour is actually required over there anyway, just saying).

@ShaneWalsh
Copy link
Collaborator Author

Ok so last part of this change, (minus the hex overlap with the wrong color, that's minor and can be done later) is to make the movement path not overlap on the creatures base hex's. However when using a abilities it should, where applicable. I may not get to this tonight, life's a bit hecktick at the moment, but I just wanted to clarify anyway.

@ShaneWalsh
Copy link
Collaborator Author

ShaneWalsh commented Nov 29, 2017

Ok I added another parameter to tracePosition to allow it to draw over the creatures tile( true by default because thats how it functioned before). When called from tracePath it is always false, so when moving a creature it should not draw the new position over the creatures base hex. Abilities that use tracePosition like scavengers escort should be unaffect because of the default value and so should function the same as before. I tested both uncle fungus and scavenger.

edit* Escort Service does not use tracePath, its a custom fnonselect, so unaffected the change.

@DreadKnight
Copy link
Member

DreadKnight commented Nov 29, 2017

@ShaneWalsh tested, moving medium/large units it's fine, but Scavenger's Escort Service targeting is rather problematic, as it should show colored outlines under the whole nearby viable target and when hovering around, should show filled hexagons for the target's new position, plus I don't see the proper overlap, as the hexagons for the new locations should replace the hexagons for current ones on hover.

@ShaneWalsh
Copy link
Collaborator Author

sorry to be a pain, but could you try and explain exactly how you would like the escort ability to work again, but maybe in bullet points. I understand that you want the target that's being moved to have a hex outline(not filled) under it once the ability is activated, thats easy to do.

The rest is a bit difficult to understand.
"when hovering around, should show filled hexagons for the target's new position," It does this already doesn't it? the new positions of both creatures are filled and flashing.

"plus I don't see the proper overlap, as the hexagons for the new locations should replace the hexagons for current ones on hover." I have no idea what you mean by this :D

@DreadKnight
Copy link
Member

Basically, when targeting Escort Service, the hexagons for the target new location can overlap (replace actually) the hexagons from under Scavenger itself and the unit that's being moved. More clear now? xD

@ShaneWalsh
Copy link
Collaborator Author

For someone as dim as me you can never be clear enough ;) I think I get the gist now. I think this will require a custom solution for the Escort Service ability.

@DreadKnight
Copy link
Member

Ok, small update on the Escort Service targeting, kinda like a train on railroad:

  • the possible target path should be done using colored outline hexagons
  • when hovering a viable location, filled colored accordingly hexagons representing both units will be moved around
  • while doing so, there won't be any duplicated hexagons displayed under Scavenger / unit
  • hovering out the viable path, filled colored hexagons should be displayed under Scavenger itself and colored outlines under the other unit

@DreadKnight
Copy link
Member

Should be most intuitive this way and avoid visual cluttering and distractions, which is what we're aiming for.

@ShaneWalsh
Copy link
Collaborator Author

I couldn't see a way to do the escort ability that was inline with the default logic so i had to add a new parameter to the queryHexes function. Can now pass in a function to be executed after the queryHexe's logic has executed. In this case we want to draw a outline around the target. So the logic is now passed in from the escort ability and executed by queryHexes.

@DreadKnight DreadKnight temporarily deployed to ancientbeast-pr-1297 November 29, 2017 22:35 Inactive
@DreadKnight
Copy link
Member

DreadKnight commented Nov 29, 2017

Good job, I've tested and it's pretty intuitive this time. Only one thing kinda bugs me about it regarding medium and large units as the opposite hexagon is not really usable (drops the avatar from queue), so perhaps differentiating that one with a dashed outline hexagon might be best for now provided it's easy.

…e dashed array because one of the larger creature hexes is on the movement path. So custom solution.
@ShaneWalsh
Copy link
Collaborator Author

Hexes on the target creatures should now be dashed, except when they are on the movement path(for medium and large creatures). Let me know if you see anything else, ill check back tomorrow. I'm gonna crash for the night

@DreadKnight DreadKnight temporarily deployed to ancientbeast-pr-1297 November 30, 2017 21:03 Inactive
@DreadKnight
Copy link
Member

Not what I was thinking but it's probably better, should do, at least for now. Good job and sleep well!

@DreadKnight DreadKnight merged commit 14e8e46 into FreezingMoon:master Nov 30, 2017
@DreadKnight
Copy link
Member

This also fixed #882

CyberBishop pushed a commit to CyberBishop/AncientBeast that referenced this pull request Apr 20, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Boom Box targeting visual tweaks
3 participants