--- deliantra/Deliantra-Client/TODO 2006/05/22 02:23:10 1.70 +++ deliantra/Deliantra-Client/TODO 2006/06/05 01:22:07 1.125 @@ -8,48 +8,45 @@ 12:17 <@schmorp> remind me of it 12:17 <@schmorp> qwhen i next bundle it -- IMPORTANT: inventory: drop should be shift-click, or aply should be shift click, normal click should no drop - (maybe also for floorbox) -- IMPORTANT: quit-button, somewhere! - * dialog, der warnt ein savebed aufzusuchen. -- IMPORTANT: win32, fow_tetxure sometimes nukes other textures -- IMPORTANT: lose/regain mapping might clear messgae log - (maybe this happens when its being updated when the window isn't mapped => no - window context?) -- IMPORTANT: ogg-vorbis not available - crash at startup, handle this better. -- IMPORTANT:_ map feedback... e.g. when clicking on it -- IMPORTANT: online documentation for the client (rig up a podviewer with textview) -- IMPORTANT: '.' in map should repeat last command -- important: center and improve dialogs (create cFClient::UI::Dialog) -- IMPORTANT: user interface (window positions etc.) should be saved, but - b) widget layout is nontrivial as to not obscure map - c) need better way to center map then middle-button, maybe map overview - (but updates will be slow UPDATE updates are not at all slow). -- IMPORTANT: verify and correct connection-dependent texture management -- IMPORTANT: force mapscaling to 2**n values, can give nasty borders otherwise -- IMPORTANT: message log slider goes too far down. -- IMPORTANT: focus mapwidget on login -- IMPORTANT: font reconfigure works very badly. +- IMPORTANT: password-entry dialog (query!) not hidden, should be fixed + together with removing query dialog altogether. +- IMPORTANT: statusbox tooltip must not go away on updates +- IMPORTANT: history for completer (cursor-up) +- IMPORTANT: toggle stats/messgae log window to visible while character creation is active. +- IMPORTANT: stats window looks like shit initially (widget allocation?) + +- binding window and editor layout broken for long recordings +- sorted spell dialog + second spell bind dialog with checkboxes: invoke and cast distinction +- minor: skill list which shows XP and lets u bind stuff should be solved/investitaged before release: +- make a real "table" for the spell list (not long strings like lvl: xxx sp: xx) + and add column titles (also for other tables like inventory and bindings) +- log messages received and commands sent to ~/.crossfire/log.$ip +- the binding editor should have a append-record mode or something like that +- rethink message display in lower left corner - cairo/win32 looks like shit (premultiplied alpha bug?) - Attempt to free unreferenced scalar: SV 0x11f5d98 during global destruction. - (after starting, pressing login with connection refused, then close window) -- flopper/menu imrpovement: - * things that are menus should act more like menus - * inmventory etc. should fade-in automatically when used -- add menu itemds for inventory items: mark/inscribe etc. -- remove wrap_mode hack from texture and make it a per-texture operation -- enter runmode when cursor-key repeats + (after starting, press quit) +- better focus management: put focus onto active windows, remove it again later +- add menu itemds for inventory items for UNcommon actions: mark/inscribe etc. +- enter runmode when cursor-key repeats (maybe not?) - mapmap (overview) - scroll visible area by clicking/dragging -- elmex: split up gauges into: head, body and foot, so that contents begin in the interior of gauges +- split up gauges into: head, body and foot, so that contents begin in the interior of gauges - maybe move window managing functionality into toplevel - better window management (graphical feedback) +- the player weight somehow updates strangely when dropping/picking up low priority: +- win32, fow_tetxure sometimes nukes other textures + (mostly fixed, but still there: displays list and texture uploads do not go well together) +- get rid of ScrolledWindow special case and use draw_xywh rectangle inside TextView for optimisation. +- completer should know more about arguments, e.g. cast summon pet monster, + or that some commands do not take arguments ("drop all"). +- textview should not snap to bottom on resize. +- alt+cursor == diagonal - look into extendedmapinfo - save only dirty cached maps, and save dirty maps != current map -- inventory update must be incremental (too slow) (really? check) - try to synchronize local animation speed with server updates to save on screen refreshes. - player list from server for tell etc. commands - examine etc., should use extendeddrawinfo or sth. similar @@ -93,3 +90,28 @@ set_face 4784 => 73 libpng warning: Ignoring gAMA chunk with gamma=0 + To achieve a more complete blending, you can have your drawing engine rasterize each transparent object more than once, altering in each pass the blending mode, object alpha channel, and buffer write masks. The first pass should perform RGB blending. Accordingly, you should disable writing any alpha channel or z buffer data during this pass. + /*first pass*/ + glColorMask(TRUE, TRUE, TRUE, FALSE); /*disable alpha channel*/ + glDepthMask(FALSE); /*disable Z buffer*/ + if (premultpliedTransparency) + glBlendFunc(GL_ONE, GL_ONE_MINUS_SRC_ALPHA); + else + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + /*render the object here*/ + + On the second pass, you should set the frame buffer alpha channel value to (1- a s )(1- a d ). To do this, you need to render the object again, with a different alpha value, as follows: + /*second pass*/ + glColorMask(FALSE, FALSE, FALSE, TRUE); /*enable alpha channel*/ + glDepthMask(FALSE); /*disable Z buffer*/ + glBlendFunc(GL_ONE_MINUS_DST_ALPHA, GL_ZERO); + /*render the object with alpha replaced with 1-a*/ + + Finally, the third pass should replace the value in the alpha channel with the final value 1-((1- a s )(1- a d )). To do this, you need to render the object again, with its alpha value set to 1, as follows: + /*third pass*/ + glColorMask(FALSE, FALSE, FALSE, TRUE); /*enable alpha channel*/ + glDepthMask(TRUE); /*enable Z buffer*/ + glBlendFunc(GL_ONE_MINUS_DST_ALPHA, GL_ZERO); + /*render the object with alpha replaced with 1*/ + +