Создать ответ 
 
Рейтинг темы:
  • Голосов: 0 - Средняя оценка: 0
  • 1
  • 2
  • 3
  • 4
  • 5
DreamShell lua source code
Автор Сообщение
zaero Не на форуме
Супермодератор
******

Сообщений: 1228
Зарегистрирован: 05.01.2005
Рейтинг: 0
Сказал спасибо: 4
Поблагодарили 2 раз(а) в 2 сообщ.
Сообщение: #21
DreamShell lua source code
Спасиб...
Уже начал работать с ней:)

[Изображение: Ubuntu-User.png]
Dreamshell fAn
(Последний раз сообщение было отредактировано 09.12.2005 в 02:14, отредактировал пользователь zaero.)
24.11.2005 19:11
Вебсайт Найти все сообщения Цитировать это сообщение
zaero Не на форуме
Супермодератор
******

Сообщений: 1228
Зарегистрирован: 05.01.2005
Рейтинг: 0
Сказал спасибо: 4
Поблагодарили 2 раз(а) в 2 сообщ.
Сообщение: #22
DreamShell lua source code
Вот чем я занимаюсь на парах по Инженерной Компьютерной Графике:

Код:
-- Engineering computer graphics (straight line on planes) by zaero
-- http://bbrclan.dc-swat.net.ru/dreamshell/


SDL.SDL_BlitSurface = SDL.SDL_UpperBlit;

SDL.SDL_Init(SDL.SDL_INIT_VIDEO);

--DS.ds_draw_shutdown();

flags = SDL.bit_or(SDL.SDL_HWSURFACE, SDL.SDL_DOUBLEBUF);
screen = SDL.SDL_SetVideoMode(640,480,16,flags);
    SDL.SDL_drawLine_TG(screen, 510, 40, 510, 30, 255, 0, SDL.SDL_TG_ANTIALIAS);
    SDL.SDL_drawLine_TG(screen, 100, 240, 240, 240, 255, 0, SDL.SDL_TG_ANTIALIAS);
    SDL.SDL_drawLine_TG(screen, 510, 450, 510, 30, 255, 0, SDL.SDL_TG_ANTIALIAS);

for i=1,400,1 do
i1=i/4
i2=i
i3=i/2
   SDL.SDL_putPixel(screen, 110+i2, 240, 255);
   SDL.SDL_putPixel(screen, 510, 40+i2, 255);
   SDL.SDL_putPixel(screen, 20+i2, 150, 255);
   SDL.SDL_putPixel(screen, 220+i2, 350, 255);
   SDL.SDL_putPixel(screen, 110+i2, 40, 255);
   SDL.SDL_putPixel(screen, 110+i2, 440, 255);
   SDL.SDL_putPixel(screen, 110, 40+i2, 255);
  
   SDL.SDL_putPixel(screen, 20+i3, 150+i3, 255);
   SDL.SDL_putPixel(screen, 420+i3, 150+i3, 255);
   SDL.SDL_drawTriangle_TG(screen, 510, 5, 515, 30, 505, 30, 255*i3+i3, 0,SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawTriangle_TG(screen, 70, 240, 100, 245, 100, 235, 255*i3+i3, 0,SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_putPixel(screen,200+i1, 240+i1, 4000);
end



   SDL.SDL_drawCircle_TG(screen, 340, 240, 5, 4000, 0, SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawCircle_TG(screen, 340, 120, 5, 4000, 0, SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawLine_TG(screen, 340, 240, 340, 120, 4000, 0, SDL.SDL_TG_ANTIALIAS)

   SDL.SDL_drawCircle_TG(screen, 200, 240, 5, 4000, 0, SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawCircle_TG(screen, 200, 100, 5, 4000, 0, SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawCircle_TG(screen, 300, 340, 5, 4000, 0, SDL.SDL_TG_ANTIALIAS);
   SDL.SDL_drawLine_TG(screen, 200, 240, 200, 100, 4000, 0, SDL.SDL_TG_ANTIALIAS)

SDL.SDL_Flip(screen);
SDL.SDL_Delay(10000);

--DS.ds_draw_init();

[Изображение: Ubuntu-User.png]
Dreamshell fAn
(Последний раз сообщение было отредактировано 08.12.2005 в 00:36, отредактировал пользователь zaero.)
24.11.2005 22:26
Вебсайт Найти все сообщения Цитировать это сообщение
zaero Не на форуме
Супермодератор
******

Сообщений: 1228
Зарегистрирован: 05.01.2005
Рейтинг: 0
Сказал спасибо: 4
Поблагодарили 2 раз(а) в 2 сообщ.
Сообщение: #23
DreamShell lua source code
Вот просмоторщик картинок следующих форматов: BMP,PNM,XPM,XCF,PCX,GIF,JPG,TIF,PNG,LBM. Умеет показывать физическое разрешение картинки и ее вес.

Код:
-- image viewer v0.1 by zaero
-- http://bbrclan.dc-swat.net.ru/dreamshell/
-- This version does not support that was for is planned
-- Коментарии не давал т.к. этот скрипт основан на примерах Свата.

if argv.n < 1 then
    print"\n==========================================="
    print"========Lua image viewer v0.1 by zaero====="
    print"==========================================="
    print"\n Flags:"
    print"      -i -- information on picture"
    print"      -o -- open file"
    print"      -v -- version"
    print" Usage:\n    view flag time(if need)"
    print" Exemple:\n    view -o /rd/image/logos/DSXT1.jpg 3000"
    print"    view -i image.jpg"
end

     SDL.SDL_BlitSurface = SDL.SDL_UpperBlit;

if argv[1]=="-v" then
     print"\nLua image viewer v0.1 by zaero, 1.12.2005";
end

function ShowIMG_xy(file, screen, x, y)
     local img_t, dest, slide, time  dest = SDL.SDL_Rect_new();
     img_t = SDL.IMG_Load(file);
           if img_t == nil then
              print("DS_ERROR: Couldn't load", file);
              return;
           end
     dest.x =x
     dest.y = y
     SDL.SDL_BlitSurface(img_t, NULL, screen, dest);
     SDL.SDL_Flip(screen);
     SDL.SDL_FreeSurface(img_t);
  end

function WhatTime(time)
     local time
         if argv[3] == nil then
              time = 3000
          else
              time = argv[3]
          end
     SDL.SDL_Delay(time)
end

if argv[1] == "-o" then
      DS.ds_draw_shutdown();
      SDL.SDL_Init(SDL.SDL_INIT_VIDEO);
      flags = SDL.bit_or(SDL.SDL_HWSURFACE, SDL.SDL_DOUBLEBUF);
      screen = SDL.SDL_SetVideoMode(640,480,16,flags);
      ShowIMG_xy(argv[2], screen, 0, 0)
      WhatTime(time);
      DS.ds_draw_init();
end

if argv[1] == "-i" then
     local width_im,  dest      
     width_im = SDL.IMG_Load(argv[2])
             if width_im == nil then
                print("DS_ERROR: Couldn't load", argv[2]);
                return;
            end
     print("-----alert--------------------------------")
     print("\nInformation on picture ",'"',argv[2],'"\n')
     print("-----end----------------------------------")
     print("\nWidth= ",width_im.w,"x",width_im.h)
     f = DS.fs_open(argv[2],DS.O_RDONLY)
     sizef = DS.fs_total(f);
     print("Size =",sizef)
end

[Изображение: Ubuntu-User.png]
Dreamshell fAn
05.12.2005 18:54
Вебсайт Найти все сообщения Цитировать это сообщение
SWAT Не на форуме
Администратор
*******

Сообщений: 7237
Зарегистрирован: 04.01.2005
Рейтинг: 30
Сказал спасибо: 149
Поблагодарили 1214 раз(а) в 762 сообщ.
Сообщение: #24
DreamShell lua source code
Небольшая примитивная игрушка.
Я переделал ее под DS, это полностью рабочая версия, в отличии от предыдущей:)
Ресурсы ее я прикрепил к сообщению.

Код:
-- meteor_shower.lua
-- by Thatcher Ulrich <tu@tulrich.com> November 2001 (updated June 2003)
-- Modified for DS and DSS by SWAT (http://www.dc-swat.net.ru)

SDL.SDL_BlitSurface = SDL.SDL_UpperBlit;

-- keep a table of previously-loaded sprites, to maximize sharing.
sprite_cache = {}

function sprite(file)
-- sprite constructor.&nbsp;&nbsp;Pass in a bitmap filename.&nbsp;&nbsp;Returns an SDL_Surface which
-- is ready to be blitted.

if sprite_cache[file] then
return sprite_cache[file]
end

local temp, s;

-- Load the sprite image
s = SDL.SDL_LoadBMP(file);
if s == nil then
print("Couldn't load " ..&nbsp;&nbsp;file .. ": " .. SDL.SDL_GetError());
return nil
end

-- Set transparent color to black (?)
SDL.SDL_SetColorKey(s, SDL.SDL_SRCCOLORKEY + SDL.SDL_RLEACCEL, 0)

-- Convert sprite to video format
temp = SDL.SDL_DisplayFormat(s);
SDL.SDL_FreeSurface(s);
if temp == nil then
print("Couldn't convert background: " .. SDL.SDL_GetError());
return nil
end
s = temp;

sprite_cache[file] = s

return s
end


function show_sprite(screen, sprite, x, y)
-- make sure we have a temporary rect structure
if not temp_rect then
temp_rect = SDL.SDL_Rect_new()
end

temp_rect.x = x - sprite.w / 2
temp_rect.y = y - sprite.h / 2
temp_rect.w = sprite.w
temp_rect.h = sprite.h

SDL.SDL_BlitSurface(sprite, NULL, screen, temp_rect)
end


--
-- vec2 type
--

vec2_meta = nil-- be sure to re-init the vector type if we reload

function vec2(t)
-- constructor

if not vec2_meta then
vec2_meta = {}
vec2_meta["__add"] =
function (a, b) return vec2{ a.x + b.x, a.y + b.y } end
vec2_meta.__sub =
function (a, b) return vec2{ a.x - b.x, a.y - b.y } end
vec2_meta.__mul =
function (a, b)
if tonumber(a) then
return vec2{ a * b.x, a * b.y }
elseif tonumber(b) then
return vec2{ a.x * b, a.y * b }
else
-- dot product.
return (a.x * b.x) + (a.y * b.y)
end
end
vec2_meta.__unm =
function (a) return vec2{ -a.x, -a.y } end
end

local v = {}
if type(t) == 'table' or getmetatable(t) == vec2_meta then
v.x = tonumber(t[1]) or tonumber(t.x) or 0
v.y = tonumber(t[2]) or tonumber(t.y) or 0
else
v.x = 0
v.y = 0
end
setmetatable(v, vec2_meta)
v.normalize = vec2_normalize
return v
end


function vec2_normalize(a)
-- normalizes a.&nbsp;&nbsp;If a has 0 or near-zero length, sets a to an arbitrary unit vector (go ahead and sue me!)

local d2 = a * a
if d2 < 0.000001 then
-- infinitesimal vector.&nbsp;&nbsp;Return arbitrary unit vector!
a.x = 1
a.y = 0
else
-- divide by the length to get a unit vector
local length = math.sqrt(d2)
a.x = a.x / length
a.y = a.y / length
end
end


gamestate = {
event_buffer = nil,
last_update_ticks = 0,
begin_time = 0,
elapsed_ticks = 0,
frames = 0,

update_period = 33,-- interval between calls to update_tick(), in ms
active = 1,

screen = nil,
background = nil,

new_actors = {},
actors = {},

add_actor = function(self, a)
assert(a)
table.insert(self.new_actors, a)
end
}


function handle_event(event)
-- called by main loop when it detects an SDL event.
if event.type == SDL.SDL_KEYDOWN then
localsym = event.key.keysym.sym
if sym == SDL.SDLK_q or sym == SDL.SDLK_ESCAPE then
gamestate.active = nil
elseif sym == SDL.SDLK_s then
-- take a screenshot...
SDL.SDL_SaveBMP(gamestate.screen, "screenshot.bmp")
end
elseif event.type == SDL.SDL_QUIT then
gamestate.active = nil
end
end


function update_tick()
-- called at regular intervals, to update the game state.

-- remove dead actors, and add in new actors
for i = 1, table.getn(gamestate.actors) do
if gamestate.actors[i].active then
-- add to the new list
table.insert(gamestate.new_actors, gamestate.actors[i])
end
end
gamestate.actors = gamestate.new_actors
gamestate.new_actors = {}

-- call the update handler for each actor
for i = 1, table.getn(gamestate.actors) do
gamestate.actors[i]:update(gamestate)
end
end


function render_frame(screen, background)
-- called to render a new frame.

-- clear screen
SDL.SDL_FillRect(screen, NULL, background);

-- draw the actors
for i = 1, table.getn(gamestate.actors) do
gamestate.actors[i]:render(screen)
end

-- flip
SDL.SDL_UpdateRect(screen, 0, 0, 0, 0)
end


function gameloop_iteration()
-- call this to update the game state.&nbsp;&nbsp;Runs update ticks and renders
-- according to elapsed time.

if gamestate.event_buffer == nil then
gamestate.event_buffer = SDL.SDL_Event_new()
end

-- consume any pending events
while SDL.SDL_PollEvent(gamestate.event_buffer) ~= 0 do
handle_event(gamestate.event_buffer)
end

-- run any necessary updates
local time = SDL.SDL_GetTicks();
local delta_ticks = time - gamestate.last_update_ticks
local update_count = 0
while delta_ticks > gamestate.update_period do
update_tick();

delta_ticks = delta_ticks - gamestate.update_period
gamestate.last_update_ticks = gamestate.last_update_ticks + gamestate.update_period
update_count = update_count + 1

-- don't let more than 3 update ticks pile up before a render
if update_count >= 3 then
gamestate.last_update_ticks = time
break
end
end

-- if we did any updates, then render a frame
if update_count > 0 then
render_frame(gamestate.screen, gamestate.background)
gamestate.frames = gamestate.frames + 1
end
end


function engine_init(argv)
local width, height;
local video_bpp;
local videoflags;
local i

-- Initialize SDL
if SDL.SDL_Init(SDL.SDL_INIT_VIDEO) < 0 then
print("Couldn't initialize SDL: ",SDL.SDL_GetError());
exit(1);
end

videoflags = SDL.SDL_HWSURFACE + SDL.SDL_ANYFORMAT-- SDL.SDL_HWSURFACE was SDL.SDL_SWSURFACE; any benefit to that?
width = 800
height = 600
video_bpp = 16
argv = argv or {}
for i = 1, table.getn(argv) do
if argv[i] == "-width" then
width = tonumber(argv[i+1]);
i = i + 1
elseif argv[i] == "-height" then
height = tonumber(argv[i+1]);
i = i + 1
elseif argv[i] == "-fullscreen" then
videoflags = videoflags + SDL.SDL_FULLSCREEN
_ = [[
elseif
if ( strcmp(argv[argc-1], "-bpp") == 0 ) {
video_bpp = atoi(argv[argc]);
videoflags = SDL.bit_and(videoflags, ~SDL.SDL_ANYFORMAT);
--argc;
} else
if ( strcmp(argv[argc], "-fast") == 0 ) {
videoflags = FastestFlags(videoflags, width, height, video_bpp);
} else
if ( strcmp(argv[argc], "-hw") == 0 ) {
videoflags ^= SDL.SDL_HWSURFACE;
} else
if ( strcmp(argv[argc], "-flip") == 0 ) {
videoflags ^= SDL.SDL_DOUBLEBUF;
} else
if ( isdigit(argv[argc][0]) ) {
numsprites = atoi(argv[argc]);
]]; _ = nil;
else
print("Usage: main_program [-bpp N] [-hw] [-flip] [-fast] [-fullscreen] [numsprites]\n");
exit(1);
end
end

-- Set video mode
gamestate.screen = SDL.SDL_SetVideoMode(width, height, video_bpp, videoflags);
if gamestate.screen == nil then
print("Couldn't set ", width, "x", height, " video mode: ", SDL.SDL_GetError());
exit(2);
end

gamestate.background = SDL.SDL_MapRGB(gamestate.screen.format, 0, 0, 0);

SDL.SDL_ShowCursor(0)

-- Print out information about our surfaces
print("Screen is at " .. gamestate.screen.format.BitsPerPixel .. " bits per pixel\n");
--if SDL.bit_and(gamestate.screen.flags, SDL.SDL_HWSURFACE) == SDL.SDL_HWSURFACE then
--print("Screen is in video memory");
--else
--print("Screen is in system memory");
--end
--if SDL.bit_and(gamestate.screen.flags, SDL.SDL_DOUBLEBUF) == SDL.SDL_DOUBLEBUF then
--print("Screen has double-buffering enabled");
--end

-- init timer
gamestate.begin_time = SDL.SDL_GetTicks();
gamestate.last_update_ticks = gamestate.begin_time;
end


function engine_loop()
-- Loop, blitting sprites and waiting for a keystroke

while gamestate.active do
gameloop_iteration()
end

-- Print out some timing information
localcurrent_time = SDL.SDL_GetTicks();
if current_time > gamestate.begin_time then
print((gamestate.frames * 1000) / (current_time - gamestate.begin_time) .. " frames per second\n");
end

SDL.SDL_Quit();
end


engine_init{
--"-fullscreen"
}


--
-- game-specific stuff
--


--
-- actor type
--


function actor_update(self, gs)
-- update this actor.&nbsp;&nbsp;Default does linear motion according to velocity.
-- gs is the gamestate

localdt = gamestate.update_period / 1000.0

-- update according to velocity &amp; time
localdelta = self.velocity * dt
self.position = self.position + delta

-- wrap around at screen edge
if self.position.x < -self.radius and self.velocity.x <= 0 then
self.position.x = self.position.x + (gs.screen.w + self.radius * 2)
end
if self.position.x > gs.screen.w + self.radius and self.velocity.x >= 0 then
self.position.x = self.position.x - (gs.screen.w + self.radius * 2)
end
if self.position.y < -self.radius and self.velocity.y <= 0 then
self.position.y = self.position.y + (gs.screen.h + self.radius * 2)
end
if self.position.y > gs.screen.h + self.radius and self.velocity.y >= 0 then
self.position.y = self.position.y - (gs.screen.h + self.radius * 2)
end

end


function actor_render(self, screen)
-- draw this actor.&nbsp;&nbsp;Default implementation blits the actor's sprite
-- to the screen at the actor's position.

show_sprite(screen, self.sprite, self.position.x, self.position.y)
end


function actor(t)
-- actor constructor.&nbsp;&nbsp;Pass in the name of a sprite bitmap.

local a = {}
-- copy elements of t
for k,v in t do
a[k] = v
end

a.type = "actor"
a.active = 1
a.sprite = (t[1] or t.sprite and sprite(t[1] or t.sprite)) or nil
a.position = vec2(t.position)
a.velocity = vec2(t.velocity)
a.radius = a.radius
or (a.sprite and a.sprite.w * 0.5)
or 0

a.update = actor_update
a.render = actor_render

return a
end


--
-- particle type
--


function particle_update(self, gs)
-- update this particle.&nbsp;&nbsp;Do linear motion, and expire after a while.
-- gs is the gamestate

localdt = gamestate.update_period / 1000.0

-- update according to velocity &amp; time
localdelta = self.velocity * dt
self.position = self.position + delta

self.countdown = self.countdown - gamestate.update_period
if self.countdown <= 0 then
-- kill ourself
self.active = nil
end
end


function particle_render(self, screen)
-- draw this actor.&nbsp;&nbsp;Default implementation blits the actor's sprite
-- to the screen at the actor's position.

show_sprite(screen, self.sprite, self.position.x, self.position.y)
end


-- shared particle sprite.&nbsp;&nbsp;@@ change this to a general shared
-- resource table used by sprite() constructor.
particle_sprite = nil


function particle(t)
-- particle constructor.

if not particle_sprite then
particle_sprite = sprite("particle.bmp")
end

-- start with actor defaults.
local a = actor(t)

a.sprite = particle_sprite
a.countdown = a.countdown or 500

-- attach particle handlers
a.update = particle_update
a.render = particle_render

return a
end


function particle_spray(position, velocity, count, spray_speed, average_life)
-- make a spray of count particles at the given location.&nbsp;&nbsp;The given
-- velocity will be applied to all particles.&nbsp;&nbsp;The spray_speed determines
-- the average dispersion speed.&nbsp;&nbsp;average_life determines the average
-- lifetime of the particle in ms.

for i = 1, count do
local p = particle{}

-- need to generate a dispersion vector, of length <= 1
-- generate random vectors until we get a good one.&nbsp;&nbsp;@@ could also try a table.
local dir
repeat
dir = vec2{ math.random() * 2 - 1, math.random() * 2 - 1 }
until dir * dir <= 1

p.position = position
p.velocity = velocity + dir * spray_speed

p.countdown = (math.random() + math.random() + math.random()) / 3 * average_life

gamestate:add_actor(p)
end
end


GRAVITY_CONSTANT = 100000


--
-- asteroid actor type
--


function asteroid_update(self, gs)
-- update this asteroid.&nbsp;&nbsp;watch for collisions with other actors.

-- move ourself
actor_update(self, gs)

localdt = gamestate.update_period / 1000
localaccel = vec2()

-- check for collisions against all other actors
for i = 1, table.getn(gs.actors) do
locala = gs.actors[i]

-- if the actor has mass and isn't the player, then compute a gravitational acceleration towards it
if a.mass and a.type ~= 'player' then
local r = a.position - self.position
local d2 = r * r

if d2 < 100 * 100 then
local d = math.sqrt(d2)

if d * 2 > self.radius then
accel = accel + r * ((GRAVITY_CONSTANT * a.mass) / (d2 * d))
end
end
end

-- check for collisions, and respond
if a and a ~= self and a.collidable then
local disp = a.position - self.position
local distance_squared = disp * disp
local sum_radius_squared = (a.radius + self.radius) ^ 2

if distance_squared < sum_radius_squared then
-- we have a collision

-- call the collision handler.
handle_collision(self, a)
end
end
end

self.velocity = self.velocity + accel * dt
end


-- table of masses for the different asteroid sizes
asteroid_masses = { 25, 50, 100 }

ASTEROID_RESTITUTION = 0.3

-- soft speed-limit on asteroids
SPEED_TURNOVER_THRESHOLD = 500


function handle_asteroid_collision(a, b)
-- handles a collision between two asteroids, a and b.

-- impulse will be along the displacement vector between the two asteroids
local normal = b.position - a.position
normal:normalize()

local relative_vel = b.velocity - a.velocity

if relative_vel * normal >= 0 then
-- don't do collision response if asteroids are moving away from each other
return
end

-- separate the colliding asteroids by making them bounce
-- away from each other a la billiard balls.
local impulse_mag =
(1 + ASTEROID_RESTITUTION) * (relative_vel * normal)
/ (1 / a.mass + 1 / b.mass)
a.velocity = a.velocity + normal * (impulse_mag / a.mass)
b.velocity = b.velocity - normal * (impulse_mag / b.mass)

-- split each asteroid into two pieces
local collision_energy = 0.5 * (relative_vel * relative_vel) * (a.mass + b.mass)
local split_dir = vec2{ normal.y, -normal.x }
asteroid_take_damage(a, split_dir, -normal, collision_energy)
asteroid_take_damage(b, split_dir, normal, collision_energy)

-- spray some particles at the split point
localavg_velocity = (a.velocity + b.velocity) * 0.5
localavg_position = (a.position + b.position) * 0.5
particle_spray(avg_position, avg_velocity, (a.size + b.size) * 2, 100 + (a.size + b.size) * 20, 300)
end


function asteroid_take_damage(a, split_direction, collision_normal, collision_energy)
-- damage the asteroid; if it's damaged enough, split the asteroid a
-- into two pieces, along the given split_direction and along the
-- given collision normal

local split_speed = math.sqrt(2 * collision_energy / a.mass) * 0.35

-- asteroid takes damage; when its damage reaches 0 then it splits
-- in two.
a.hitpoints = a.hitpoints - collision_energy / 2000

if a.hitpoints > 0 then
-- collision is not violent enough to split this 'roid
return
end

local new_size = a.size - 1
if new_size < 1 then
-- can't split the smallest asteroid -- it just disintegrates.
a.active = nil
particle_spray(a.position, a.velocity, 6, 100, 300)
add_score(100)
return
end

-- spawn child asteroids

localdir
dir = (collision_normal + split_direction) * (1 / 1.414)
local child1 = asteroid{
size = new_size,
position = a.position,
velocity = a.velocity + dir * split_speed
}
child1.position = child1.position + dir * child1.radius * 2
gamestate:add_actor(child1)

dir = (collision_normal - split_direction) * (1 / 1.414)
local child2 = asteroid{
size = new_size,
position = a.position,
velocity = a.velocity + dir * split_speed
}
child2.position = child2.position + dir * child2.radius * 2
gamestate:add_actor(child2)

-- make some particles at the split point
particle_spray(a.position, a.velocity, 5 + a.size * 2, 100 + a.size * 20, 300)

-- kill a
a.active = nil

if a.size == 2 then
add_score(30)
else
add_score(10)
end
end


asteroid_images = {
{ "ast1.bmp" },
{ "ast2.bmp" },
{ "ast3.bmp" },
}

function pick_asteroid_image(size)
local image_table = asteroid_images[size]

-- pick one of the asteroid images at random
return image_table[math.random(table.getn(image_table))]
end


function asteroid(t)
-- constructor

-- start with a regular actor
local a = actor(t)

a.type = "asteroid"
a.collidable = 1
a.size = a.size or 3-- make sure caller defined one of the three sizes of asteroid
a.sprite = sprite(pick_asteroid_image(a.size))
a.radius = 0.5 * a.sprite.w
a.mass = asteroid_masses[a.size]
a.hitpoints = a.mass * a.mass

-- implement a soft speed-limit on asteroids
localspeed = math.sqrt(a.velocity * a.velocity)
if speed > SPEED_TURNOVER_THRESHOLD then
local new_speed = SPEED_TURNOVER_THRESHOLD + math.sqrt(speed - SPEED_TURNOVER_THRESHOLD)
a.velocity = a.velocity * (new_speed / speed)
end


-- attach the behavior handlers
a.update = asteroid_update

return a
end


--
-- random asteroid spewer
--


function asteroid_spewer(t)
-- constructs an actor that randomly spawns a new asteroid periodically

a = {}
a.active = 1
a.type = "asteroid_spewer"
a.collidable = nil
a.position = vec2{ 0, 0 }
a.velocity = vec2{ 0, 0 }
a.sprite = nil

a.period = t.period or t[0] or 1000-- period, in ms, between spawning asteroids
a.countdown = a.period

a.render = function () end
a.update =
function (self, gs)
self.countdown = self.countdown - gs.update_period
if self.countdown < 0 then
-- timer has expired; spawn an asteroid

-- pick a random spot around the edge of the screen
local w, h = gs.screen.w, gs.screen.h
local edge = math.random(w * 2 + h * 2)
local pos
if edge < w then
pos = vec2{ edge, 0 }
elseif edge < w*2 then
pos = vec2{ edge - w, h }
elseif edge < w*2 + h then
pos = vec2{ 0, edge - w*2 }
else
pos = vec2{ w, edge - (w*2 + h) }
end

-- aim at the middle of the screen
local vel = vec2{ w/2, h/2 } - pos
vel:normalize()
vel = vel * (math.random(50) + 50)

gs:add_actor(
asteroid{
size = 3,
position = pos,
velocity = vel
}
)

-- reset the timer
self.countdown = self.period
end
end

return a
end


--
-- player actor type
--


function player_update(self, gs)
-- update this asteroid.&nbsp;&nbsp;watch for collisions with other actors.

localdt = gamestate.update_period / 1000

-- get the mouse position, and move the player position towards the mouse position
localm = {}
m.buttons, m.x, m.y = SDL.SDL_GetMouseState(0, 0)
localmpos = vec2{ m.x, m.y }

localdelta = mpos - self.position
localaccel =
delta * 50-- move towards the mouse cursor
- self.velocity * 10-- damping

self.velocity = self.velocity + accel * dt

-- spray some particles according to the acceleration
particle_spray(self.position, accel * -0.10, math.floor(math.sqrt(accel * accel) * 0.0015), 150, 200)

-- move ourself
actor_update(self, gs)

-- check for collisions against all other actors
for i = 1, table.getn(gs.actors) do
locala = gs.actors[i]

-- check for collisions, and respond
if a and a ~= self and a.collidable then
local disp = a.position - self.position
local distance_squared = disp * disp
local sum_radius_squared = (a.radius + self.radius) ^ 2

if distance_squared < sum_radius_squared then
-- we have a collision

-- call the collision handler.
handle_player_collision(self, a)
end
end
end

end


function handle_player_collision(a, b)
-- handles a collision between a player, a, and some other object, b

-- impulse will be along the displacement vector between the two asteroids
local normal = b.position - a.position
normal:normalize()

local relative_vel = b.velocity - a.velocity

if relative_vel * normal >= 0 then
-- don't do collision response if asteroids are moving away from each other
return
end

-- separate the colliding objects by making them bounce
-- away from each other a la billiard balls.
local impulse_mag =
(1 + ASTEROID_RESTITUTION) * (relative_vel * normal)
/ (1 / a.mass + 1 / b.mass)
if a.mass and a.mass > 0 then
a.velocity = a.velocity + normal * (impulse_mag / a.mass)
end
if b.mass and b.mass > 0 then
b.velocity = b.velocity - normal * (impulse_mag / b.mass)
end

if b.type == "asteroid" then
-- split asteroid 'b' into two pieces
local collision_energy = 0.5 * (relative_vel * relative_vel) * (a.mass + b.mass)
local split_dir = vec2{ normal.y, -normal.x }
asteroid_take_damage(b, split_dir, normal, collision_energy)
end

-- kill off the player
a.active = nil
end


function player(t)
-- constructor

-- start with a regular actor
local a = actor(t)

a.type = "player"
a.collidable = 1
a.sprite = sprite("saucer.bmp") -- or error("can't load ....")
a.radius = 0.5 * a.sprite.w
a.mass = 10

-- attach the behavior handlers
a.update = player_update

return a
end

--
-- cursor actor type
--

function cursor_update(self, gs)
-- update the cursor.&nbsp;&nbsp;follow the mouse.

localm = {}
m.buttons, m.x, m.y = SDL.SDL_GetMouseState(0, 0)
self.position.x = m.x
self.position.y = m.y

if m.buttons ~= 0 then
-- player has clicked
self.active = nil
end
end


function cursor(t)
-- constructor

-- start with a regular actor
local a = actor(t)

a.type = "cursor"
a.sprite = sprite("cursor.bmp") -- or error("can't load ....")
a.radius = 0.5 * a.sprite.w

-- attach the behavior handlers
a.update = cursor_update

return a
end

--
-- player manager actor
--

SHIPS_PER_GAME = 3
BASE_SPEW_PERIOD = 2000

function player_manager_update(self, gs)
-- keep track of game functions

if self.state == "pre-setup" then
-- delay, and then enter setup mode.
self.countdown = self.countdown - gamestate.update_period
if self.countdown <= 0 then
self.state = "setup"

self.cursor.active = 1
gamestate:add_actor(self.cursor)
end

elseif self.state == "setup" then
if not self.cursor.active then
-- player has placed her ship.&nbsp;&nbsp;start playing.

self.player.active = 1
self.player.position = self.cursor.position
gamestate:add_actor(self.player)

-- deduct the ship that we just placed.
self.ships = self.ships - 1

self.state = "playing"
end

elseif self.state == "playing" then
if not self.player.active then
-- player has died.

if self.ships <= 0 then
-- game is over
self.state = "pre-attract"
self.countdown = 1000
else
-- set up for next ship
self.state = "pre-setup"
self.countdown = 1000
end

-- slow down the asteroid spawning
self.asteroid_spewer.period = BASE_SPEW_PERIOD
end

elseif self.state == "pre-attract" then
-- delay, and then enter attract mode
self.countdown = self.countdown - gamestate.update_period
if self.countdown <= 0 then
self.state = "attract"
end

elseif self.state == "attract" then
local m = {}
m.buttons, m.x, m.y = SDL.SDL_GetMouseState(0, 0)
if m.buttons > 0 then
-- start a new game.
self.state = "pre-setup"
self.ships = SHIPS_PER_GAME
self.score = 0

self.countdown = 1000
end

--elseif self.state == "" then

end
end

digit_sprites = nil

function player_manager_render(self, screen)
if self.state == "attract" then
show_sprite(screen, self.game_over_sprite, screen.w / 2, screen.h / 2)
else
-- show the ships remaining
local sprite = self.player.sprite
local x = sprite.w
local y = screen.h - sprite.h
for i = 1, self.ships do
show_sprite(screen, sprite, x, y)
x = x + sprite.w
end
end

-- show the score
if not digit_sprites then
digit_sprites = {}
for i = 0,9 do
digit_sprites[i] = sprite("d" .. i .. ".bmp")
end
end

localx = screen.w - digit_sprites[0].w
localy = 0 + digit_sprites[0].h
localscore = self.score
repeat
localdigit = math.mod(score, 10)
x = x - digit_sprites[digit].w
show_sprite(screen, digit_sprites[digit], x, y)

score = math.floor(score / 10)
until score <= 0
end

manager = nil

function player_manager(t)
-- constructor

local a = {}
for k, v in t do a[k] = v end-- copy values from t

a.active = 1
a.ships = SHIPS_PER_GAME
a.state = "setup"
a.score = 0

a.cursor = cursor{
}
gamestate:add_actor(a.cursor)

a.player = player{
position = { gamestate.screen.w / 2, gamestate.screen.h / 2 },
velocity = { 0, 0 },
}

a.asteroid_spewer.period = BASE_SPEW_PERIOD
a.game_over_sprite = sprite("gameover.bmp")
a.update = player_manager_update
a.render = player_manager_render

-- keep a global pointer to the player_manager, for score management.&nbsp;&nbsp;@@ this is a bit grody.
if not manager then
manager = a
end
return a
end


free_ship_schedule = {
-- { threshold, interval }
{ 0, 10000 },
{ 20000, 20000 },
{ 100000, 50000 },
{ 200000, 100000 }
}


function add_score(x)
-- increase the score by x

if manager then
if manager.state == "playing" then

localscore0 = manager.score

-- increment the score
manager.score = manager.score + x

-- award free ships at various intervals
localthreshold = 0
localinterval = 10000
for i = 1, table.getn(free_ship_schedule) do
if score0 >= free_ship_schedule[i][1] then
threshold = free_ship_schedule[i][1]
interval = free_ship_schedule[i][2]
end
end

localdelta = math.floor((manager.score - threshold) / interval) - math.floor((score0 - threshold) / interval)
if delta > 0 then
-- award ships
manager.ships = manager.ships + delta
end

-- adjust asteroid spewing rate
localramp = math.exp(-manager.score / 10000) + 0.5
manager.asteroid_spewer.period = (1 + math.sin(manager.score / 500) * 0.25) * ramp * BASE_SPEW_PERIOD
end
end
end

--
-- game collision handler
--
-- I'm sidestepping the double-dispatch problem by just putting
-- the game-specific collision smarts in this function.


function handle_collision(a, b)
-- handles a collision between actors a and b.
-- uses the actor's "type" attributes to help decide what to do.
-- disp is the displacement vector; (b.position - a.position)

if a.type == "asteroid" and b.type == "asteroid" then
handle_asteroid_collision(a, b, disp)
end
-- @@ handle more collision cases here...
end

--
-- initialize the game
--

-- Generate a bunch of asteroids
for i = 1,10 do
gamestate:add_actor(
asteroid{
position = { math.random(gamestate.screen.w), math.random(gamestate.screen.h) },
velocity = { (math.random()*2 - 1) * 100, (math.random()*2 - 1) * 100 },-- pixels/sec
size = math.random(3)
}
)
end

-- create an asteroid spewer
spewer = asteroid_spewer{}
gamestate:add_actor(spewer)

-- create a player manager
gamestate:add_actor(
player_manager{
asteroid_spewer = spewer
}
)

-- run the game
engine_loop()


Прикрепления
.zip  meteor_shower.zip (Размер: 17.64 Кб / Загрузок: 70)

[Изображение: barbers.png]
(Последний раз сообщение было отредактировано 06.06.2006 в 08:58, отредактировал пользователь SWAT.)
05.06.2006 14:13
Вебсайт Найти все сообщения Цитировать это сообщение
zaero Не на форуме
Супермодератор
******

Сообщений: 1228
Зарегистрирован: 05.01.2005
Рейтинг: 0
Сказал спасибо: 4
Поблагодарили 2 раз(а) в 2 сообщ.
Сообщение: #25
DreamShell lua source code
Спасибки за сорсы. Позже гляну их =))

ПС от SWAT
Я заменил их, но все же забыл добавить специфические для DS функции, для закрытия и открытия графики DS.
В DSS работает на 100%.

[Изображение: Ubuntu-User.png]
Dreamshell fAn
(Последний раз сообщение было отредактировано 06.06.2006 в 09:02, отредактировал пользователь SWAT.)
06.06.2006 01:59
Вебсайт Найти все сообщения Цитировать это сообщение
SWAT Не на форуме
Администратор
*******

Сообщений: 7237
Зарегистрирован: 04.01.2005
Рейтинг: 30
Сказал спасибо: 149
Поблагодарили 1214 раз(а) в 762 сообщ.
Сообщение: #26
DreamShell lua source code
Вот пример использования экрана DreamShell:

Код:
-- DreamShell NG lua script
-- SDL test with DS screen.



local screen = SDL.GetDScreen();

SDL.SDL_BlitSurface = SDL.SDL_UpperBlit;

function ShowIMG(file, screen)
local img_t

img_t = SDL.IMG_Load(file);

if img_t == nil then
print("DS_ERROR: Couldn't load ", file);
&nbsp;&nbsp;return;
end

SDL.SDL_BlitSurface(img_t, NULL, screen, NULL);
SDL.SDL_Flip(screen);
SDL.SDL_FreeSurface(img_t);
end


function ShowIMG_xy(file, screen, x, y)
local img_t, dest

dest = SDL.SDL_Rect_new();

img_t = SDL.IMG_Load(file);

&nbsp;&nbsp;if img_t == nil then
&nbsp;&nbsp;print("DS_ERROR: Couldn't load ", file);
return;
&nbsp;&nbsp;end

dest.x = x
dest.y = y
dest.w = img_t.w
dest.h = img_t.h

SDL.SDL_BlitSurface(img_t, NULL, screen, dest);
SDL.SDL_Flip(screen);
SDL.SDL_FreeSurface(img_t);
SDL.SDL_Rect_delete(dest);
end


-- Закрываем графику DreamShell
DS.ds_draw_shutdown();

-- Показываем картинку
ShowIMG("/Cd/image/logos/DS_NG.jpg", screen)

-- Ждем 3 секунды
SDL.SDL_Delay(3000);

-- Показываем картинку с указанием координат
ShowIMG_xy("/cd/image/logos/DS_NG.jpg", screen, 100, 50)

-- Ждем 3 секунды
SDL.SDL_Delay(3000);

-- Инициализируем назад графику DreamShell
DS.ds_draw_init();

Вообщем то проще некуда:)

[Изображение: barbers.png]
10.08.2006 17:06
Вебсайт Найти все сообщения Цитировать это сообщение
SWAT Не на форуме
Администратор
*******

Сообщений: 7237
Зарегистрирован: 04.01.2005
Рейтинг: 30
Сказал спасибо: 149
Поблагодарили 1214 раз(а) в 762 сообщ.
Сообщение: #27
DreamShell lua source code
Небольшой пример для рисования графических оболочек с помощью DreamShell GUI API.

Код:
-- DreamShell NG lua script
-- GUI test (input and button)



local font

local btn_img = {

normal = nil,
highlight = nil,
pressed = nil,
disabled = nil

}





-- Сделаем функцию для удобного рисования кнопок.
function NormalButton(name, x, y, font, img,&nbsp;&nbsp;text, func, data)

-- Создаем кнопку.
local button = SDL.GUI_ButtonCreate(name, x, y, 110, 60);

-- Создаем текст.
local label = SDL.GUI_LabelCreate("label", 0, 0, 110, 60, font, text);

-- Наносим текст на кнопку.
SDL.GUI_ButtonSetCaption(button, label);
--SDL.GUI_ObjectDecRef(label);


-- Присваиваем действие к кнопке(функцию которую она выполнит).
--&nbsp;&nbsp;local cb = SDL.GUI_CallbackCreate(func, nil, data);
--&nbsp;&nbsp;SDL.GUI_ButtonSetClick(button, cb);
--&nbsp;&nbsp;SDL.GUI_ObjectDecRef(cb);


-- Устанавливаем картинки к кнопке для разных ее режимов.
SDL.GUI_ButtonSetNormalImage(button, img.normal);
SDL.GUI_ButtonSetHighlightImage(button, img.highlight);
SDL.GUI_ButtonSetPressedImage(button, img.pressed);
SDL.GUI_ButtonSetDisabledImage(button, img.disabled);

return button
end






function callbackf(param)

if param == "Exit" then

SDL.GUI_SetRunning(0);
SDL.GUI_Quit();

end

end



function CreateContents(x, y, w, h)

-- Создаем панель(невидимую) на которой будем рисовать.
local box = SDL.GUI_PanelCreate("box", x, y, w, h);

-- Рисуем форму для ввода текста.
local input = SDL.GUI_TextEntryCreate("button", 20, 305, 200, 30, font, 32);

-- Устанавливаем в форме текст.
SDL.GUI_TextEntrySetText(input, "Exit");

-- Добавляем нашу форму в панель.
SDL.GUI_ContainerAdd(box, input);
--&nbsp;&nbsp; SDL.GUI_ObjectDecRef(input);

-- Рисуем кнопку с помощью нашей функции.
local button = NormalButton("TestButton", 260, 350, font, btn_img, "OK", callbackf, SDL.GUI_TextEntryGetText(input));

SDL.GUI_ContainerAdd(box, button);
--&nbsp;&nbsp; SDL.GUI_ObjectDecRef(button);


return box;
end




function Init_gui(w, h)

-- Берем экран GUI.
local screen = SDL.GUI_GetScreen();

-- Загружаем шрифт.
font = SDL.GUI_FontLoadTrueType("/cd/fonts/comic.ttf", 18);

-- Загружаем фоновую картинку.
local background = SDL.GUI_SurfaceLoad("/cd/image/back/water.jpg");

-- Загружаем картинки для нашей кнопки.
btn_img.normal = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/normal.png");
btn_img.highlight = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/highlight.png");
btn_img.pressed = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/pressed.png");
btn_img.disabled = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/disabled.png");

-- Проверяем, загрузили ли мы нужные ресурсы.
if font == nil then return 0 end
if background == nil then return 0 end
-- И так далее :)


-- Устанавливаем фон.
SDL.GUI_ScreenSetBackground(screen, background);
--&nbsp;&nbsp; SDL.GUI_ObjectDecRef(background);


-- Создаем наше творение.
local mainpage = CreateContents(0,0,w,h);
SDL.GUI_ScreenSetContents(screen, mainpage);
--&nbsp;&nbsp; SDL.GUI_ObjectDecRef(mainpage);


--&nbsp;&nbsp; SDL.GUI_ObjectDecRef(font);
font = 0;
return 1;
end




-- Закрываем графику DreamShell
DS.ds_draw_shutdown();

-- Устанавливаем режим GUI
DS.conio_set_mode(3, 3);

-- Если играет музыка, остановим ее, иначе лаганет :)
DS.ds_exec_one("ogg stop");

-- Запускаем
if Init_gui(640, 480) then

-- Loop
SDL.GUI_Run();

end


-- Возвращаем режим
DS.conio_set_mode(1, 1);

-- Возвращаем графику DreamShell
DS.ds_draw_init();



Функции которые находянся в коментарии, являются бажными:(
Там есть проблема с типами аргументов, как всегда млин я с этим сталкиваюсь когда внедряю функции Си в lua.
В принципе главной проблемой является то, что к кнопке не назначить callback функцию, а на DecRef пофиг. А кнопка без действий, это не кнопка:)
Похоже придется выпускать обновление:)А то это уже не первый косяк который я заметил:rolleyes:
Все остальные функции GUI должны работать, теоретически:)все проверить нехватает времени.

[Изображение: barbers.png]
(Последний раз сообщение было отредактировано 10.08.2006 в 19:20, отредактировал пользователь SWAT.)
10.08.2006 19:16
Вебсайт Найти все сообщения Цитировать это сообщение
SWAT Не на форуме
Администратор
*******

Сообщений: 7237
Зарегистрирован: 04.01.2005
Рейтинг: 30
Сказал спасибо: 149
Поблагодарили 1214 раз(а) в 762 сообщ.
Сообщение: #28
DreamShell lua source code
Ну вот и нашел я решение проблемы:)
Во ттак теперь это будет выглядеть:


Код:
-- DreamShell NG lua script
-- GUI test v1.0 (input and button)

local font


local btn_img = {

normal = nil,
highlight = nil,
pressed = nil,
disabled = nil

}





-- Сделаем функцию для удобного рисования кнопок.
function NormalButton(name, x, y, font, img,&nbsp;&nbsp;text, func)

-- Создаем кнопку.
local button = SDL.GUI_ButtonCreate(name, x, y, 110, 60);

-- Создаем текст.
local label = SDL.GUI_LabelCreate("label", 0, 0, 110, 60, font, text);

-- Наносим текст на кнопку.
SDL.GUI_ButtonSetCaption(button, label);
SDL.GUI_ObjectDecRef(SDL.GUI_AnyToObject(label));


-- Присваиваем действие к кнопке(функцию которую она выполнит).
-- Эта функция есть только в поледнем обновлении.
local cb = SDL.GUI_LuaCallbackCreate(func);
SDL.GUI_ButtonSetClick(button, cb);


-- Устанавливаем картинки к кнопке для разных ее режимов.
SDL.GUI_ButtonSetNormalImage(button, img.normal);
SDL.GUI_ButtonSetHighlightImage(button, img.highlight);
SDL.GUI_ButtonSetPressedImage(button, img.pressed);
SDL.GUI_ButtonSetDisabledImage(button, img.disabled);

return button
end





local input

function GetInputText()
&nbsp;&nbsp;return SDL.GUI_TextEntryGetText(input);
end



function callbackf(param)

if param == "Exit" then

SDL.GUI_SetRunning(0);
SDL.GUI_Quit();

end


end



function CreateContents(x, y, w, h)

-- Создаем панель(невидимую) на которой будем рисовать.
local box = SDL.GUI_PanelCreate("box", x, y, w, h);

-- Рисуем форму для ввода текста.
input = SDL.GUI_TextEntryCreate("button", 20, 305, 200, 30, font, 32);

-- Устанавливаем в форме текст.
SDL.GUI_TextEntrySetText(input, "Exit");

-- Добавляем нашу форму в панель.
SDL.GUI_ContainerAdd(box, input);

-- Рисуем кнопку с помощью нашей функции.
local button = NormalButton("TestButton", 260, 350, font, btn_img, "OK", "callbackf(GetInputText())");

SDL.GUI_ContainerAdd(box, button);


return box;
end




function Init_gui(w, h)

-- Берем экран GUI.
local screen = SDL.GUI_GetScreen();

-- Загружаем шрифт.
print("Loading font...")
font = SDL.GUI_FontLoadTrueType("/cd/fonts/comic.ttf", 18);

-- Загружаем фоновую картинку.
print("Loading background...")
local background = SDL.GUI_SurfaceLoad("/cd/image/back/water.jpg");

-- Загружаем картинки для нашей кнопки.
print("Loading button images...")
btn_img.normal = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/normal.png");
btn_img.highlight = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/highlight.png");
btn_img.pressed = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/pressed.png");
btn_img.disabled = SDL.GUI_SurfaceLoad("/cd/image/gui/buttons/normal/disabled.png");

-- Проверяем, загрузили ли мы нужные ресурсы.
if font == nil then return 0 end
if background == nil then return 0 end
-- И так далее :)


print("Creating content...")

-- Устанавливаем фон.
SDL.GUI_ScreenSetBackground(screen, background);


-- Создаем наше творение.
local mainpage = CreateContents(0,0,w,h);
SDL.GUI_ScreenSetContents(screen, mainpage);
SDL.GUI_ObjectDecRef(SDL.GUI_AnyToObject(mainpage));

font = 0;
return 1;
end




function LoadUpdate(fn)

local f = KOS.fs_open(fn, KOS.O_RDONLY);
if f < 0 then return 0 end
KOS.fs_close(f);

DS.ds_exec_one(string.format("vmcp -tf %s /ram/ds_update.klz", fn));
DS.ds_exec_one("gz -d /ram/ds_update.klz /ram/ds_update.klf");
DS.ds_exec_one("module -open DSUpdate /ram/ds_update.klf");
DS.ds_exec_one("rm /ram/ds_update.klz");
DS.ds_exec_one("rm /ram/ds_update.klf");
return 1;
end




-- Если играет музыка, остановим ее, иначе лаганет :)
DS.ds_exec_one("ogg stop");


-- Загружаем модуль последних обновлений
-- (если вы зами его не загружали до этого)
if LoadUpdate("/vmu/a1/DSUPDATE.KLZ") == 0 then
print("Can't open latest DreamShell update module.")
print("This script cannot run without update.")
return
end




-- Запускаем
if Init_gui(640, 480) then

-- Закрываем графику DreamShell
DS.ds_draw_shutdown();

-- Устанавливаем режим GUI
DS.conio_set_mode(3, 3);

-- Loop
print("Run GUI API...")
SDL.GUI_Run();

-- Возвращаем режим
DS.conio_set_mode(1, 1);
print("GUI API is shutting down.")

-- Возвращаем графику DreamShell
DS.ds_draw_init();

print("Welcome to back in DreamShell console :)")

end


Обновление можно скачать на страничке DreamShell.

[Изображение: barbers.png]
(Последний раз сообщение было отредактировано 12.08.2006 в 18:43, отредактировал пользователь SWAT.)
12.08.2006 18:37
Вебсайт Найти все сообщения Цитировать это сообщение
zaero Не на форуме
Супермодератор
******

Сообщений: 1228
Зарегистрирован: 05.01.2005
Рейтинг: 0
Сказал спасибо: 4
Поблагодарили 2 раз(а) в 2 сообщ.
Сообщение: #29
DreamShell lua source code
самый простой пример прокрутки текста в консоле:

Код:
x = 'вашь текст';

-- значение i = 0 (с 0 символа в строке)
i = "0"
-- значение j = 100 (по 100 символ в строке)
j = "100"

-- выводим длину переменной x
print (string.len (x));

function mytext(i,j, oper)
&nbsp;&nbsp; -- очищаем экран консоли
&nbsp;&nbsp; for i=0, 1000, 1 do
print " "
&nbsp;&nbsp; end

-- выводим наш тескт с параметрами i,j
print (string.sub (x, i, j));

-- прокручиваем ткст вниз и увеличиваем каждую переменную на 10
if oper == "down" then
i =&nbsp;&nbsp;i+10
j =&nbsp;&nbsp;j+10
print ("i=",i)
print ("j=",j)
myfunc(i,j)
end

-- прокручивам текст вверх и уменьшаем каждую переменную на 10
if oper == "up" then
i =&nbsp;&nbsp;i-10
j =&nbsp;&nbsp;j-10
print ("i=",i)
print ("j=",j)
myfunc(i,j)
end
end


local ibuff = {}
local bc = 0
local exit = 1

function myfunc(i,j)

-- ждем ввода с клавиатуры
&nbsp;&nbsp; while exit do

-- 96 (тильда), 50 (цифра 2 на цифровой клавиатуре), 56 (цифра 8 на цифровой клавиатуре)
ibuff[bc] = DS.getchar()

if ibuff[bc] == 96 then
break
end

if ibuff[bc] == 50 then
mytext(i,j, "down")
end

if ibuff[bc] == 56 then
mytext(i,j, "up")
end
&nbsp;&nbsp; bc = bc+1
&nbsp;&nbsp; end
end

myfunc(i,j)

[Изображение: Ubuntu-User.png]
Dreamshell fAn
(Последний раз сообщение было отредактировано 19.12.2006 в 04:39, отредактировал пользователь zaero.)
19.12.2006 04:36
Вебсайт Найти все сообщения Цитировать это сообщение
SWAT Не на форуме
Администратор
*******

Сообщений: 7237
Зарегистрирован: 04.01.2005
Рейтинг: 30
Сказал спасибо: 149
Поблагодарили 1214 раз(а) в 762 сообщ.
Сообщение: #30
DreamShell lua source code
По просьбам трудящихся:)


Код:
-- Урок по управлению контентом GUI




function CreatePage1(int x, int y, int w, int h)

local box = SDL.GUI_PanelCreate("box", x, y, w, h);

-- Добавляем сюда что хотим, любые элементы GUI

return box;
end



function CreatePage2(int x, int y, int w, int h)

local box = SDL.GUI_PanelCreate("box", x, y, w, h);

-- Добавляем сюда что хотим, любые элементы GUI

return box;
end



function CreateMainPage(int x, int y, int w, int h)

local box = SDL.GUI_PanelCreate("box", x, y, w, h);

-- Добавляем сюда что хотим, любые элементы GUI

return box;
end





function CreateContents(x, y, w, h)

local box = SDL.GUI_PanelCreate("main", x, y, w, h);
local page;
local cards;

cards = SDL.GUI_CardStackCreate("cards", 0, 0, w, h-50);
SDL.GUI_ContainerAdd(box, cards);

-- Создаем несколько страничек, которые потом можем показывать по выбору.

page = SDL.CreateMainPage(0, 0, w, h-50);
SDL.GUI_ContainerAdd(cards, page);

page = SDL.CreatePage1(0, 0, w, h-50);
SDL.GUI_ContainerAdd(cards, page);

page = SDL.CreatePage2(0, 0, w, h-50);
SDL.GUI_ContainerAdd(cards, page);



-- Здесь нижняя часть экрана, теперь всегда одна и та же,
-- выделили мы под нее 50 пикселей, делаем с ними что хотим, например меню

-- code



-- Сообщаем какая страница откроется первой.
-- мы выбрали самую первую страницу(под нулевым значением), называется у нас MainPage
-- В дальнейшем эта функция вам пригодится для перехода по вашим страничкам,
-- например в вышенаписанном меню.

SDL.GUI_CardStackShowIndex(cards, 0);

return box;
end


function AppInit(w, h)

local screen = SDL.GUI_GetScreen();
local mainpage;
local background;



-- Тут загружаем картинку которую растянем на фон.

background = GUI_SurfaceLoad("background.jpg");

if background == nil then
print("ERROR: Can't load gui background.");
end

-- Тут и так думаю понятно по названию функций :)

SDL.GUI_ScreenSetBackground(screen, background);

mainpage = SDL.CreateContents(0,0,w,h);

SDL.GUI_ScreenSetContents(screen, mainpage);

return 1;
end






-- Запускаем
if AppInit(640, 480) then

-- Закрываем графику DreamShell
DS.ds_draw_shutdown();

-- Устанавливаем режим GUI
DS.conio_set_mode(3, 3);

-- Loop
print("Run GUI API...")
SDL.GUI_Run();

-- Возвращаем режим
DS.conio_set_mode(1, 1);
print("GUI API is shutting down.")

-- Возвращаем графику DreamShell
DS.ds_draw_init();

print("Welcome to back in DreamShell console :)")

end


Не проверял на работоспособность, т.к. в принципе нечего проверять:)
Так что если где то чуть ошибся, звиняйте:)

[Изображение: barbers.png]
(Последний раз сообщение было отредактировано 29.01.2007 в 21:03, отредактировал пользователь SWAT.)
29.01.2007 20:58
Вебсайт Найти все сообщения Цитировать это сообщение
Создать ответ 


Похожие темы
Тема: Автор Ответов: Просмотров: Посл. сообщение
  Need help building Dreamshell Rio 10 3447 01.07.2024 09:11
Посл. сообщение: SWAT
  DreamShell dev environment setup on macOS VeraBecker 17 10863 19.09.2023 06:25
Посл. сообщение: SWAT
  Приложение для DreamShell SuperClaw 170 438882 01.05.2016 08:12
Посл. сообщение: SWAT
  DreamShell 4.0 - XML Doc SWAT 6 36636 06.04.2015 13:41
Посл. сообщение: SWAT
  DreamShell 4.0 - Module dev SWAT 8 33223 23.12.2013 13:20
Посл. сообщение: SWAT
  Dreamshell BETA3/BETA4 Direct Swap atreyu187 3 20765 09.09.2011 14:27
Посл. сообщение: SWAT
  DreamShell 4.0 - App dev SWAT 3 23304 22.06.2011 23:09
Посл. сообщение: Jirohn
  DreamShell 4.0 - Bug Report SWAT 54 176299 28.03.2011 07:24
Посл. сообщение: SWAT
  Разработка блокнота для DreamShell zaero 28 93759 31.01.2011 16:02
Посл. сообщение: SWAT
  DreamShell 4.0 - Beta Testing SWAT 76 243681 14.07.2010 20:58
Посл. сообщение: SWAT

Переход:


Пользователи просматривают эту тему: 1 Гость(ей)