-
Notifications
You must be signed in to change notification settings - Fork 145
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
Nether portals and mechanics #426
Open
JustTalDevelops
wants to merge
33
commits into
master
Choose a base branch
from
feature/nether-portals
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
33 commits
Select commit
Hold shift + click to select a range
646907e
Initial implementation of nether portals (WIP)
JustTalDevelops 78f1ade
block/portal.go: Simply portal deactivation on neighbour change.
JustTalDevelops f777865
player/player.go: Make Travel exported.
JustTalDevelops 694f4c2
world/world.go: Moved Place checks to the PlaceBlock function.
JustTalDevelops 5b72308
block/portal.go: Fix destroying a frame not destroying all frames.
JustTalDevelops d6e58bd
player/player.go: Default the portal timeout to true.
JustTalDevelops 50b9b73
player/player.go: Don't request a new transfer during a transfer if t…
JustTalDevelops bed9456
block/portal.go: Destroy portals when water flows into a frame.
JustTalDevelops 5577268
portal/scan.go: Allow portals that don't specify requirements to be m…
JustTalDevelops 656a992
portal/scan.go: Fix completion check.
JustTalDevelops 69c1c07
player/player.go: Ensure the position is only translated if the sourc…
JustTalDevelops 8711c67
portal/scan.go: Simplify logic.
JustTalDevelops 38c3928
Revert "portal/scan.go: Simplify logic."
JustTalDevelops fc2cf59
Fix multi-axis scan logic
JustTalDevelops ade7b4d
Detect portal collision using their block models
JustTalDevelops cdc901c
player/player.go: Fix typo.
JustTalDevelops 95bc01e
portal/nether.go: Fixed intersecting portals.
JustTalDevelops 7a76d60
model/portal.go: Fix missing zero before decimal point.
JustTalDevelops eedec39
Allow fire blocks to be overridden by portal ignition
JustTalDevelops fca683d
Implement TravelComputers for other entities that can travel through …
JustTalDevelops 8538faf
entity/travel.go: Slightly increase AABB growth.
JustTalDevelops 51f7e36
Use the *world.World provided in Tick.
JustTalDevelops 4431fa3
entity/travel.go: Only grow AABB after the BlocksAround call
JustTalDevelops 479d6b6
Merge remote-tracking branch 'origin/master' into feature/nether-portals
JustTalDevelops d8d8f3a
block/portal.go: Fix typo.
JustTalDevelops b45deae
Remove world.Entity as an Instantaneous parameter
JustTalDevelops b431bd7
Undo unnecessary ordering
JustTalDevelops 3bb09b0
entity/travel.go: Update Traveller doc.
JustTalDevelops 611f4aa
Use an interface to detect a portal collision
JustTalDevelops 8223c9c
Merge branch 'master' into feature/nether-portals
JustTalDevelops 5e3b773
portal/nether.go: Various fixes.
JustTalDevelops 0295a6f
Merge branch 'master' into feature/nether-portals
JustTalDevelops cfc74d7
entity/travel.go: Various improvements.
JustTalDevelops File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
package model | ||
|
||
import ( | ||
"github.com/df-mc/dragonfly/server/block/cube" | ||
"github.com/df-mc/dragonfly/server/world" | ||
"github.com/go-gl/mathgl/mgl64" | ||
) | ||
|
||
// Portal is a model used by portal blocks. | ||
type Portal struct { | ||
// Axis is the axis which the portal faces. | ||
Axis cube.Axis | ||
} | ||
|
||
// BBox ... | ||
func (p Portal) BBox(cube.Pos, *world.World) []cube.BBox { | ||
min, max := mgl64.Vec3{0, 0, 0.375}, mgl64.Vec3{1, 1, 0.25} | ||
if p.Axis == cube.Z { | ||
min[0], min[2], max[0], max[2] = 0.375, 0, 0.25, 1 | ||
} | ||
return []cube.BBox{cube.Box(min[0], min[1], min[2], max[0], max[1], max[2])} | ||
} | ||
|
||
// FaceSolid ... | ||
func (Portal) FaceSolid(cube.Pos, cube.Face, *world.World) bool { | ||
return false | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
package block | ||
|
||
import ( | ||
"github.com/df-mc/dragonfly/server/block/cube" | ||
"github.com/df-mc/dragonfly/server/block/model" | ||
"github.com/df-mc/dragonfly/server/world" | ||
"github.com/df-mc/dragonfly/server/world/portal" | ||
) | ||
|
||
// Portal is the translucent part of the nether portal that teleports the player to and from the Nether. | ||
type Portal struct { | ||
transparent | ||
|
||
// Axis is the axis which the portal faces. | ||
Axis cube.Axis | ||
} | ||
|
||
// Model ... | ||
func (p Portal) Model() world.BlockModel { | ||
return model.Portal{Axis: p.Axis} | ||
} | ||
|
||
// Portal ... | ||
func (Portal) Portal() world.Dimension { | ||
return world.Nether | ||
} | ||
|
||
// HasLiquidDrops ... | ||
func (p Portal) HasLiquidDrops() bool { | ||
return false | ||
} | ||
|
||
// EncodeBlock ... | ||
func (p Portal) EncodeBlock() (string, map[string]interface{}) { | ||
return "minecraft:portal", map[string]interface{}{"portal_axis": p.Axis.String()} | ||
} | ||
|
||
// NeighbourUpdateTick ... | ||
func (p Portal) NeighbourUpdateTick(pos, _ cube.Pos, w *world.World) { | ||
if n, ok := portal.NetherPortalFromPos(w, pos); ok && (!n.Framed() || !n.Activated()) { | ||
n.Deactivate() | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
package entity | ||
|
||
import ( | ||
"github.com/df-mc/dragonfly/server/block/cube" | ||
"github.com/df-mc/dragonfly/server/world" | ||
"github.com/df-mc/dragonfly/server/world/portal" | ||
"github.com/go-gl/mathgl/mgl64" | ||
"math" | ||
"sync" | ||
"time" | ||
) | ||
|
||
// TravelComputer handles the interdimensional travelling of an entity. | ||
type TravelComputer struct { | ||
// Instantaneous is a function that returns true if the entity given can travel instantly. | ||
Instantaneous func() bool | ||
|
||
mu sync.RWMutex | ||
start time.Time | ||
awaitingTravel bool | ||
travelling bool | ||
timedOut bool | ||
} | ||
|
||
// Traveller represents a world.Entity that can travel between dimensions. | ||
type Traveller interface { | ||
world.Entity | ||
// Teleport teleports the entity to the position given. | ||
Teleport(pos mgl64.Vec3) | ||
} | ||
|
||
// portalBlock represents a block that can be used as a portal to travel between dimensions. | ||
type portalBlock interface { | ||
world.Block | ||
// Portal returns the dimension that the portal leads to. | ||
Portal() world.Dimension | ||
} | ||
|
||
// TickTravelling checks if the player is colliding with a nether portal block. If so, it teleports the player | ||
// to the other dimension after four seconds or instantly if instantaneous is true. | ||
func (t *TravelComputer) TickTravelling(e Traveller) { | ||
w := e.World() | ||
box := e.BBox().Translate(e.Position()).Grow(0.25) | ||
|
||
min, max := box.Min(), box.Max() | ||
minX, minY, minZ := int(math.Floor(min[0])), int(math.Floor(min[1])), int(math.Floor(min[2])) | ||
maxX, maxY, maxZ := int(math.Ceil(max[0])), int(math.Ceil(max[1])), int(math.Ceil(max[2])) | ||
found, target := false, world.Dimension(nil) | ||
for y := minY; y <= maxY; y++ { | ||
for x := minX; x <= maxX; x++ { | ||
for z := minZ; z <= maxZ; z++ { | ||
pos := cube.Pos{x, y, z} | ||
p, ok := w.Block(pos).(portalBlock) | ||
if !ok { | ||
continue | ||
} | ||
for _, blockBox := range p.Model().BBox(pos, w) { | ||
if blockBox.Translate(pos.Vec3()).IntersectsWith(box) { | ||
found, target = true, p.Portal() | ||
break | ||
} | ||
} | ||
} | ||
} | ||
} | ||
|
||
t.mu.Lock() | ||
defer t.mu.Unlock() | ||
if !found { | ||
if t.travelling { | ||
// Don't reset if we're travelling. | ||
return | ||
} | ||
t.timedOut, t.awaitingTravel = false, false | ||
return | ||
} | ||
|
||
switch target { | ||
case world.Nether: | ||
if t.timedOut { | ||
// Timed out, we can't travel through Nether portals. | ||
return | ||
} | ||
if t.Instantaneous() || (t.awaitingTravel && time.Since(t.start) >= time.Second*4) { | ||
t.mu.Unlock() | ||
t.Travel(e, w, w.PortalDestination(world.Nether)) | ||
t.mu.Lock() | ||
} else if !t.awaitingTravel { | ||
t.start, t.awaitingTravel = time.Now(), true | ||
} | ||
} | ||
} | ||
|
||
// Travel moves the player to the given Nether or Overworld world, and translates the player's current position based | ||
// on the source world. | ||
func (t *TravelComputer) Travel(e Traveller, source *world.World, destination *world.World) { | ||
sourceDimension, targetDimension := source.Dimension(), destination.Dimension() | ||
pos := cube.PosFromVec3(e.Position()) | ||
if sourceDimension == world.Overworld { | ||
pos = cube.Pos{pos.X() / 8, pos.Y() + sourceDimension.Range().Min(), pos.Z() / 8} | ||
} else if sourceDimension == world.Nether { | ||
pos = cube.Pos{pos.X() * 8, pos.Y() - targetDimension.Range().Min(), pos.Z() * 8} | ||
} | ||
|
||
t.mu.Lock() | ||
defer t.mu.Unlock() | ||
t.travelling, t.timedOut, t.awaitingTravel = true, true, false | ||
|
||
go func() { | ||
spawn := pos.Vec3Middle() | ||
if netherPortal, ok := portal.FindOrCreateNetherPortal(destination, pos, 128); ok { | ||
spawn = netherPortal.Spawn().Vec3Middle() | ||
} | ||
|
||
destination.AddEntity(e) | ||
e.Teleport(spawn) | ||
|
||
t.mu.Lock() | ||
defer t.mu.Unlock() | ||
t.travelling = false | ||
}() | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not sure if I'm a massive fan of the term
Travel
andTraveller
, it really doesn't make it clear that this is about portals. Do you reckon we could name this anything else?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am honestly not sure, I'm pretty awful at naming things lmao
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you have any suggestions?