| Age | Commit message (Collapse) | Author | 
|---|
|  | Make consistent with the source directory structure naming. | 
|  |  | 
|  | The highlight on the little green sphere was white-washing
the entire thing due to its high specular reflection value.
This produces more reasonable results... | 
|  | Was a constant at 20, this allows it to be specified per-object. | 
|  | Make spheres a little more diverse in terms of specular/diffusion,
and minor tweak to the plane color. | 
|  |  | 
|  | Make the camera orbit around the origin at a varying radius, with kept aimed
facing the origin, with some vertical sweep+tilt thrown in. | 
|  | This is unoptimized, with a palette slapped together in vim, but still
pretty neat! | 
|  | We should only consider dot products > 0 as intersected, or >= something
very close to 0 (epsilon).
As-is resulted in planes moving with camera movement along the plane normal
axis.
Also fixes plane distance to be non-negative in the current scene. | 
|  | Leftover from debugging presumably | 
|  | Originally I only implemented pitch->yaw->roll, and being new to all this
didn't fully appreciate the limitation that resulted in.
This adds all six permutations of pitch/yaw/roll, the scene must specify
the desired order when setting up the camera with the euler angles, see
the enum in ray_euler.h. | 
|  | trace_ray() bumps the depth, the reflection ray trace_ray() call just needs to
propagate the depth variable not advance it as well.  This was probably
vestigial from early development and never got taken out.
This does mean more reflections now, and correspondingly slower rendering, but
it at least makes MAX_RECURSION_DEPTH accurate.  The define can be changed if
the performance is too bad. | 
|  |  | 
|  | sparkler and stars both cleared fragments and drew individual pixels into fragments, add that functionality to fb.h and cleanup sparkler and stars accordingly. | 
|  |  | 
|  |  | 
|  | Currently just a memset wrapper... but maybe could get noop'd if
the flipper thread started supporting pre-zeroing pages in its thread,
just need a zeroed state in the fb page. | 
|  | drop draw_pixel() duplication | 
|  |  | 
|  | discards draw_pixel(), introduces helpers.h and a convenience
function for bounds checking and oob extermination.  Move makergb
to helpers.h, draw.h gets removed in a later commit. | 
|  | Modules seem to be duplicating this, just pull it into fb.h since we're
already dependent on the fb.h abstractions in the modules.  Slippery slope! | 
|  | If a z-buffer is added these checks will need to be done independent from and
prior to drawing.  Also it's silly to makergb() pixels which can't be drawn. | 
|  | Simple x,y coordinate check | 
|  | - Move source to src/ subdir
- Use $(top_srcdir)/src instead of ../../ | 
|  | The relative path broke out-of-tree builds.
Previously the following:
$ mkdir /tmp/foo
$ cd /tmp/foo
$ ~/src/rototiller/configure
$ make
Would fail to compile unable to locate the headers in
~/rototiller/src
This fixes it. | 
|  | Restoring some organizational sanity since adopting autotools. | 
|  | If NUM_FB_PAGES was redefined to 1 rototiller would hang, since 1 is
insufficient for page-flipping. | 
|  |  | 
|  |  | 
|  | (78d9c385ae3a1939e059c674ba5649df99d5615c) | 
|  | As this stuff is all generated we don't want to ever check it in... | 
|  | Not everyone knows about `autoreconf --install` | 
|  |  | 
|  | Now the usual ./configure && make should suffice. | 
|  | Builds were getting too time consuming, autotools is a very simple way
to get incremental builds without having to dick with Makefiles myself. | 
|  | stars: add starfield simulator from ph1l/stars | 
|  |  | 
|  | vestigial deficiency from variable gravity experiment
also reduced gravity, the results seem more aesthetically pleasing. | 
|  | More of 86bc322, eliminate per-particle unnecessary calls | 
|  | This is a trivial optimization which makes a substantial difference.
When we're doing things like explosions, thousands of occupants get
added to the bsp tree at the exact same position.  Without the lookup
cache we end up traversing the octree down to its maximum depthrepeatedly,
because the bv containing the explosion is of course full and maximally
deep.
Now explosions don't need to spend a bunch of time in the octree just to
keep locating the same full bv the explosion occurs in. | 
|  |  | 
|  | trivial per-particle savings | 
|  |  | 
|  | Multiplies tend to be less costly | 
|  | Stride needs to be considered as part of width, this is wrong,
funnily none of my test systems exposed it. | 
|  |  | 
|  |  | 
|  | With the current checkerboard pattern the majority of the interpolation
being performed is pointless.
Of course with a more complex texture this won't be as beneficial, but for
now it makes a significant FPS improvement. | 
|  | Minor formatting changes | 
|  | Rather than using whatever the existing drm_crtc->mode is, present all
modes on the chosen connector and let the user pick. |