Skip to content

An advanced ocean system implemented in Unity3D

License

Notifications You must be signed in to change notification settings

furkan59/crest-oceanrender

This branch is 4024 commits behind wave-harmonic/crest:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

c244df5 · Jun 8, 2019
May 19, 2019
Jun 8, 2019
Apr 3, 2018
Oct 14, 2018
Mar 10, 2019
Mar 24, 2019
Mar 24, 2019
Apr 7, 2019
May 5, 2019
Mar 3, 2019
May 5, 2019
May 20, 2019
Jun 3, 2019

Repository files navigation

 

Intro

Crest is a technically advanced ocean renderer implemented in Unity3D 2018.3 and later. This version targets the built-in render pipeline, a link to the LWRP version on the Asset Store is below.

Teaser

Discord for news/updates/discussions: https://discord.gg/g7GpjDC

Twitter: @crest_ocean

LWRP asset: Crest Ocean System LWRP

Gallery

Your game here! I'm looking for projects to showcase - if you upload a video of your work to youtube and send me a link I'll put a thumbnail here and link to it.

Documentation

Refer to USERGUIDE.md for full documentation, including Initial setup steps.

There is also a getting started video here: https://www.youtube.com/watch?v=qsgeG4sSLFw&t=142s .

Prerequisites

  • Unity version:
    • Releases specify which version of Unity they were developed on.
    • The master branch generally moves forward with Unity releases to take advantage of improvements. It's rare that we take a hard dependency on a new feature in the core Crest code, so it is usually possible to stand Crest up in earlier versions of Unity.
    • One exception to the previous point is the async readback API used to read collisions and flow data back to the CPU. This code will need to be manually disabled on pre-2018 versions.
    • Another exception is prefabs which are used sparingly in Crest and generally do not change much between releases, but are moved forward with Unity versions and are have limited backwards compatibility.
  • Crest example content:
    • The content requires a layer named Terrain which should be added to your project.
    • The post processing package is used (for aesthetic reasons), if this is not present in your project you will see an unassigned script warning which you can fix by removing the offending script.
  • .NET 4.x runtime

Releases

Releases are published semi-regularly and posted on the Releases page. Unity packages are uploaded with each release. Since development stability has historically been good, an option would be to grab the latest version from the master branch instead of waiting for releases. Be aware though that we actively refactor/cleanup/change the code to pay technical debt and fight complexity so integrations may require some fixup.

Crest exercises semantic versioning and follows the branching strategy outlined here, although there is no develop branch used yet - development occurs on feature branches that are merged directly into master.

Issues

If you encounter an issue, please search the Issues page to see if there is already a resolution, and if you don't find one then please report it as a new issue.

There are a few issues worth calling out here:

  • Crest does not yet support HDRP. If you would find such support useful, please feel free to comment in issue #201.
  • Azure[Sky] requires some code to be added to the ocean shader for the fogging/scattering to work. This is a requirement of this product and apparently comes with instructions for what needs to be added. See issue #62.
  • Issue with LWRP and VR - refraction appears broken due to what seems to be a bug in LWRP. See issue #206.
  • Unity 2018.3 introduced significant changes to prefabs. We don't make extensive use of prefabs, but there are some for boats and others, and these may not work in earlier versions. These will need to be recreated manually.

About

An advanced ocean system implemented in Unity3D

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C# 64.1%
  • ShaderLab 16.4%
  • C 11.0%
  • HLSL 6.0%
  • C++ 2.5%