view TaskManager/Test/test_render/task/DrawSpan.h @ 360:4430f0bff5cb draft

add vacuum "-sg 16"
author aaa
date Fri, 17 Jul 2009 22:50:06 +0900
parents 5ae96eb47e1d
children 205e4a4af635
line wrap: on
line source

#ifndef INCLUDED_TASK_DRAW_SPAN
#define INCLUDED_TASK_DRAW_SPAN

#ifndef INCLUDED_SCHED_TASK
#  include "SchedTask.h"
#endif

#ifndef INCLUDED_TAPESTRY
#  include "Tapestry.h"
#endif

#ifndef INCLUDED_SPAN_PACK
#  include "SpanPack.h"
#endif

#ifndef INCLUDED_TEXTURE_HASH
#  include "TileHash.h"
#endif

class DrawSpan : public SchedTask {
public:
    SchedConstructor(DrawSpan);

    int *linebuf;
    float *zRow;
    TileHashPtr hash;
    TileListPtr tileList;
    int doneWrite;

    ~DrawSpan(void);

    int run(void *rbuf, void *wbuf);

    int* linebuf_init(int width, int height, int rgb);
    float* zRow_init(int width, int height);
    TilePtr set_rgb(uint32 *addr, int wait_tag);
    void set_rgbs(uint32 *addr, uint32 *max_addr, int wait_tag);
    uint32 get_rgb(int tx, int ty, TilePtr tile);
    TilePtr isAvailableTile(uint32 *addr);
    uint32* getTile(int tx, int ty, int tw, uint32 *tex_addr_top);
    int getTexBlock(int tx, int ty, int twidth);
    void writebuffer(unsigned int display, int width, int height,
		     int screen_width);
    void updateBuffer(float zpos, int rangex, int x, int y,
		      int tex_x, int tex_y, float normal_x, float nomral_x, float normal_z, TilePtr tile);


    void reboot(SpanPackPtr spack, int cur_span_x);

    int drawDot1(SpanPtr span, int startx, int endx, int wait_tag);
    void drawDot2(SpanPtr span, int startx, int endx, int js, int wait_tag);
    int drawLine1(SpanPtr span, int startx, int endx, int wait_tag);
    void drawLine2(SpanPtr span, int startx, int endx, int js, int wait_tag);
    int infinity_light_calc(int color,float normal_x, float normal_y, float normal_z);
};

typedef struct {
    uint32 display;
    int screen_width;
    int rangex_start;
    int rangex_end;
    int rangey;
} DrawSpanArg, *DrawSpanArgPtr;

#endif