No description
Find a file
2019-11-26 10:52:21 -08:00
.github/workflows Remove upload step and unlabel job from builds 2019-11-21 15:37:08 -08:00
android Github actions 2019-11-18 15:20:37 -08:00
assignment-client Merge pull request #16492 from jennaingersoll/jsdoc-revisions 2019-11-19 11:01:18 -08:00
cmake On Linux, remove quazip5 dynamic libs 2019-11-21 16:32:54 -08:00
debian fix ubuntu debian patch to track changes to Qt library handling 2019-06-04 13:29:16 -07:00
docs Add collision pick documentation on scaleWithParent option 2018-09-28 09:55:02 -07:00
domain-server Merge in Howard's 'screenshare presence' open PR 2019-11-13 10:11:16 -08:00
ice-server Store big web requests on disk 2018-05-24 17:30:32 -07:00
interface Put away animation into resource and update script to use local resource path. 2019-11-21 14:50:05 -08:00
launchers Github actions 2019-11-18 15:20:37 -08:00
libraries fix linux build 2019-11-22 11:35:23 -08:00
plugins Github actions 2019-11-18 15:20:37 -08:00
screenshare forgot to add the actual var! 2019-11-18 09:52:55 -08:00
script-archive Fixed paths to included files and collision with 'clamp' 2019-07-02 14:24:02 -07:00
scripts Put away animation into resource and update script to use local resource path. 2019-11-21 14:50:05 -08:00
server-console Restore server-console dependencies 2019-11-18 15:20:37 -08:00
tests Github actions 2019-11-18 15:20:37 -08:00
tests-manual Github actions 2019-11-18 15:20:37 -08:00
tools code review feedback 2019-11-26 10:52:21 -08:00
unpublishedScripts Don't display "CLOSE" and "BACK" buttons at top of Blocks screen 2019-09-28 11:30:57 +12:00
.clang-format Update clang-format ctor initializer list format 2018-02-22 09:30:47 -08:00
.editorconfig adjust indentation and implement editorconfig at root of repo 2016-11-28 17:10:59 -08:00
.eslintrc.js Added HifiAbout (used in interstitialPage.js) 2018-10-19 09:04:22 -04:00
.gitattributes New android toolchain 2017-09-19 13:45:12 -07:00
.gitignore update gitignore 2019-08-27 16:17:11 -07:00
BUILD.md DEV-2794: Update BUILD.MD 2019-11-21 14:37:24 -08:00
BUILD_ANDROID.md made android instructions more general and added VS 2019 support 2019-05-24 19:06:38 -07:00
BUILD_LINUX.md Merge master into 22007-hifiQtBuildv2 2019-05-15 14:10:30 -07:00
BUILD_LINUX_CHEATSHEET.md Fix BUILD_LINUX_CHEATSHEET.md formatting 2018-01-18 17:09:51 -08:00
BUILD_OSX.md Updating readme's. 2019-04-30 08:32:25 -07:00
BUILD_WIN.md PR feedback 2019-08-08 10:07:40 -07:00
CMakeGraphvizOptions.cmake Trying to fix QtQml/QtScript crashes 2017-06-22 16:39:57 -07:00
CMakeLists.txt Force rebuild for mac build issue 2019-11-21 07:52:15 -08:00
CODING_STANDARD.md minor edits 2019-03-29 15:55:09 -07:00
CONTRIBUTING.md Updated coding standard link 2019-03-29 14:57:09 -07:00
hifi_android.py update webrtc library for android 2019-07-30 14:09:34 -07:00
hifi_qt.py Github actions 2019-11-18 15:20:37 -08:00
hifi_singleton.py Add FLock to lock files another way 2019-05-08 15:00:50 -07:00
hifi_utils.py Github actions 2019-11-18 15:20:37 -08:00
hifi_vcpkg.py Github actions 2019-11-18 15:20:37 -08:00
INSTALL.md Merge mess... 2019-01-24 16:30:21 -08:00
LICENSE Updated the license date 2018-04-30 18:28:21 -07:00
prebuild.py Github actions 2019-11-18 15:20:37 -08:00
README.md remove worklist.net references 2019-11-19 16:29:09 -08:00
VCPKG.md Adding new package guidance 2018-11-08 14:55:29 -08:00

High Fidelity (hifi) is an early-stage technology lab experimenting with Virtual Worlds and VR.

This repository contains the source to many of the components in our alpha-stage virtual world. The project embraces distributed development.
If you find a small bug and have a fix, pull requests are welcome.

We're hiring! We're looking for skilled developers; send your resume to hiring@highfidelity.com

Chat with us

Come chat with us in our Gitter if you have any questions or just want to say hi!

Documentation

Documentation is available at docs.highfidelity.com, if something is missing, please suggest it via a new job on Worklist (add to the hifi-docs project).

There is also detailed documentation on our coding standards.

Contributor License Agreement (CLA)

Technology companies frequently receive and use code from contributors outside the company's development team. Outside code can be a tremendous resource, but it also carries responsibility. Best practice for accepting outside contributions consists of an Apache-type Contributor License Agreement (CLA). We have modeled the High Fidelity CLA after the CLA that Google presents to developers for contributions to their projects. This CLA does not transfer ownership of code, instead simply granting a non-exclusive right for High Fidelity to use the code youve contributed. In that regard, you should be sure you have permission if the work relates to or uses the resources of a company that you work for. You will be asked to sign our CLA when you create your first PR or when the CLA is updated. You can also review it here. We sincerely appreciate your contribution and efforts toward the success of the platform.

Build Instructions

All information required to build is found in the build guide.

Running Interface

When you launch interface, you will automatically connect to our default domain: "root.highfidelity.io".

If you don't see anything, make sure your preferences are pointing to root.highfidelity.io (set your domain via Cmnd+D/Cntrl+D). If you still have no luck, it's possible our servers are down. If you're experiencing a major bug, let us know by adding an issue to this repository. Include details about your computer and how to reproduce the bug in your issue.

To move around in-world, use the arrow keys (and Shift + up/down to fly up or down) or W A S D, and E or C to fly up/down. All of the other possible options and features are available via menus in the Interface application.

Running your own servers

The assignment-client and domain-server are architectural components that will allow you to run the full stack of the virtual world.

In order to set up your own virtual world, you need to set up and run your own local "domain".

The domain-server gives a number different types of assignments to the assignment-client for different features: audio, avatars, voxels, particles, meta-voxels and models.

Follow the instructions in the build guide to build the various components.

From the domain-server build directory, launch a domain-server.

./domain-server

Then, run an assignment-client. The assignment-client uses localhost as its assignment-server and talks to it on port 40102 (the default domain-server port).

In a new Terminal window, run:

./assignment-client

Any target can be terminated with Ctrl-C (SIGINT) in the associated Terminal window.

This assignment-client will grab one assignment from the domain-server. You can tell the assignment-client what type you want it to be with the -t option. You can also run an assignment-client that forks off n assignment-clients with the -n option. The -min and -max options allow you to set a range of required assignment-clients. This allows you to have flexibility in the number of assignment-clients that are running. See --help for more options.

./assignment-client --min 6 --max 20

To test things out, you'll need to run the Interface client.

To access your local domain in Interface, open your Preferences. On OS X, this is available in the Interface menu. On Linux, you'll find it in the File menu. Enter "localhost" in the "Domain server" field.

If everything worked, you should see that you are connected to at least one server. Nice work!