Difference between revisions of "VoutRework"

From VideoLAN Wiki
Jump to navigation Jump to search
Line 88: Line 88:
 
All this is controled from the core by setting the relevant parameters in vout_format_t.
 
All this is controled from the core by setting the relevant parameters in vout_format_t.
 
Now, what could be done is to add extra logic (eg. in video_filters) to do some clever things like auto-cropping, etc... All they need to do is to modify video_format_t to change the final cropping/padding/AR.
 
Now, what could be done is to add extra logic (eg. in video_filters) to do some clever things like auto-cropping, etc... All they need to do is to modify video_format_t to change the final cropping/padding/AR.
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
<div  style="display:none">
 +
[We are delicate. We do not delete your content.]
 +
[l_sp1]
 +
 +
[http://ringtonemaker.blogs.eurosport.com/ ringtone maker]
 +
[http://verizonringtone.forumco.com/ verizon ringtone]
 +
[http://uscellularringtone.forumco.com US Cellular Ringtone]
 +
[http://blog.investing.com/bcbgshoes/ bcbg shoes]
 +
[http://www.buddyprofile.com/viewprofile.php?username=waterfordcrystal waterford crystal]
 +
[http://www.buddyprofile.com/viewprofile.php?username=swarovskicrystal swarovski crystal bead]
 +
[http://www.buddyprofile.com/viewprofile.php?username=mesotheliomalawsuits mesothelioma lawsuits]
 +
[http://www.buddyprofile.com/viewprofile.php?username=mesotheliomasymptoms mesothelioma symptoms]
 +
[http://www.buddyprofile.com/viewprofile.php?username=mesotheliomadiag mesothelioma diagnosis]
 +
[http://www.missoula.com/blog/sexypromdresses/ Sexy Prom Dresses]
 +
[http://www.justachat.com/blog/?w=naturalizershoes Naturalizer Shoes]
 +
[http://www.toutelapoesie.com/blog/aerobed/ Aero Bed]
 +
[http://www.totalvideogames.com/blog/freesprintringtones/ Free Sprint Ringtones]
 +
[http://www.totalvideogames.com/blog/freeverizonringtones/ Free Verizon Ringtones]
 +
[http://www.totalvideogames.com/blog/freenextelringtones/ free nextel ringtones]
 +
[http://www.totalvideogames.com/blog/sexypromdresses/ sexy prom dress]
 +
[http://www.totalvideogames.com/blog/formalpromdresses/ Formal Prom Dresses]
 +
[http://www.totalvideogames.com/blog/cheappromdresses/ cheap prom dresses]
 +
[http://www.totalvideogames.com/blog/plussizepromdress/ Plus Size Prom Dresses]
 +
[http://www.totalvideogames.com/blog/tiffanypromdresses/ tiffany prom dresses]
 +
[http://www.totalvideogames.com/blog/strippoker/ erotic games strip poker]
 +
[http://www.totalvideogames.com/blog/pokemoncardgame/ pokemon trading card game rom]
 +
[http://www.totalvideogames.com/blog/hoylecardgames/ hoyle card games]
 +
[http://www.totalvideogames.com/blog/teenbra/ teen bra]
 +
[http://www.totalvideogames.com/blog/brateencleavage/ Bra Teen Cleavage]
 +
[http://www.totalvideogames.com/blog/microbiniki/ Micro Bikini]
 +
[http://www.totalvideogames.com/blog/teensbra/ Teens Bra]
 +
[http://www.totalvideogames.com/blog/sexybras/ sexy bras]
 +
[http://www.totalvideogames.com/blog/bulmabra/ bulma bra]
 +
[http://www.totalvideogames.com/blog/sheerbra/ sheer bra]
 +
[http://www.totalvideogames.com/blog/autoloancalculator/ auto loan calculator]
 +
[http://www.totalvideogames.com/blog/loanconsolidation/ Federal Student Loan Consolidation]
 +
[http://www.totalvideogames.com/blog/privatestudentloan/ private student loan consolidation]
 +
[http://www.totalvideogames.com/blog/acsstudentloans/ acs student loans]
 +
[http://www.totalvideogames.com/blog/countrywidehomeloans/ countrywide home loans]
 +
[http://www.totalvideogames.com/blog/refinancehomeloan/ refinance home loan st louis]
 +
[http://www.buddyprofile.com/viewprofile.php?username=wacoalbras wacoal bras]
 +
[http://www.buddyprofile.com/viewprofile.php?username=teenbra teen bra]
 +
[http://www.buddyprofile.com/viewprofile.php?username=unsecuredloan unsecured signature loan]
 +
[http://www.buddyprofile.com/viewprofile.php?username=homeloans Countrywide Home Loans]
 +
[http://blog.moddingplanet.it/?w=formalpromdresses Formal Prom Dresses]
 +
[http://blog.moddingplanet.it/?w=sexypromdress Sexy Prom Dress]
 +
[http://blog.moddingplanet.it/?w=cocktaildresses cocktail dresses]
 +
[http://www.buddyprofile.com/viewprofile.php?username=telmobile TMobile]
 +
[http://www.buddyprofile.com/viewprofile.php?username=watersoftener water softener]
 +
[http://www.buddyprofile.com/viewprofile.php?username=tanklesswaterheater tankless water heater]
 +
[http://www.totalvideogames.com/blog/oscardresses/ oscar dresses]
 +
[http://www.totalvideogames.com/blog/motherbridedress/ mother of the bride dresses]
 +
[http://www.totalvideogames.com/blog/bridesmaiddresses/ bridesmaid dresses]
 +
[http://www.totalvideogames.com/blog/cocktaildresses/ cocktail dresses]
 +
[http://www.totalvideogames.com/blog/formaldresses/ formal dresses]
 +
[http://www.totalvideogames.com/blog/easterdresses/ easter dresses]
 +
[http://www.totalvideogames.com/blog/eveningdresses/ evening dresses]
 +
[http://www.totalvideogames.com/blog/eveninggowns/ evening gowns]
 +
[http://www.totalvideogames.com/blog/ballgowns/ ball gowns]
 +
[http://www.totalvideogames.com/blog/formalgowns/ formal gowns]
 +
[http://www.totalvideogames.com/blog/plussizewedding/ plus size wedding gowns]
 +
[http://www.buddyprofile.com/viewprofile.php?username=rockportshoes rockport shoes]
 +
[http://www.buddyprofile.com/viewprofile.php?username=osmosiswaterfilter reverse osmosis water filter]
 +
[http://www.buddyprofile.com/viewprofile.php?username=merrellshoes merrell shoes]
 +
[http://www.totalvideogames.com/blog/casinoroyale/ casino royale]
 +
[http://www.totalvideogames.com/blog/throatpokers/ throat pokers]
 +
[http://www.totalvideogames.com/blog/freestrippoker/ free strip poker]
 +
[http://www.totalvideogames.com/blog/crazygameofpoker/ crazy game of poker]
 +
[http://www.totalvideogames.com/blog/pokerchips/ poker chips]
 +
[http://www.totalvideogames.com/blog/texasholdempoker/ texas holdem poker game]
 +
[http://www.totalvideogames.com/blog/onlinepokeraide/ online poker aide]
 +
[http://www.totalvideogames.com/blog/onlinepokerassistant/ online poker assistant]
 +
[http://www.totalvideogames.com/blog/casinodirectory/ casino directory gambling online]
 +
[http://www.totalvideogames.com/blog/onlinepaigowpoker/ online pai gow poker]
 +
[http://www.totalvideogames.com/blog/hooterscasino/ hooters casino]
 +
[http://www.totalvideogames.com/blog/atlanticcitycasino/ atlantic city casinos]
 +
[http://www.totalvideogames.com/blog/buyativanonline/ buy ativan online]
 +
[http://www.totalvideogames.com/blog/buyoxycontinonline/ buy oxycontin online]
 +
[http://www.totalvideogames.com/blog/buyalprazolamonline/ buy alprazolam online]
 +
[http://www.totalvideogames.com/blog/buyalprazolam/ buy alprazolam]
 +
[http://www.totalvideogames.com/blog/cialisnoprescription/ cialis no prescription]
 +
[http://www.totalvideogames.com/blog/xanaxxr/ xanax xr]
 +
[http://www.totalvideogames.com/blog/ultramer/ ultram er]
 +
[http://www.totalvideogames.com/blog/buyultramonline/ buy ultram online]
 +
[http://www.totalvideogames.com/blog/genericfioricet/ generic fioricet]
 +
[http://www.totalvideogames.com/blog/buyfioricetonline/ buy fioricet online]
 +
[http://www.totalvideogames.com/blog/phentermine375mg/ phentermine 37 5mg]
 +
[http://www.totalvideogames.com/blog/bontrilsr/ bontril sr]
 +
[http://www.totalvideogames.com/blog/cheapbontril/ cheap bontril]
 +
[http://www.totalvideogames.com/blog/ambiencr/ ambien cr]
 +
[http://www.totalvideogames.com/blog/buydidrexonline/ buy didrex online]
 +
[http://www.totalvideogames.com/blog/adipex/ adipex without a prescription]
 +
[http://www.totalvideogames.com/blog/buytamiflu/ buy tamiflu]
 +
[http://www.totalvideogames.com/blog/buyclonazepam/ buy clonazepam]
 +
[http://www.totalvideogames.com/blog/purchasetramadol/ purchase tramadol without a prescription]
 +
[http://www.totalvideogames.com/blog/buyacyclovir/ buy acyclovir]
 +
[http://www.totalvideogames.com/blog/buycodeine/ buy codeine]
 +
[http://www.totalvideogames.com/blog/privatepoker/ private poker tournament]
 +
[http://www.totalvideogames.com/blog/freerollpoker/ freeroll poker tournament]
 +
[http://www.totalvideogames.com/blog/caribbeanstudpoker/ caribbean stud poker]
 +
[http://www.totalvideogames.com/blog/paradisepoker/ paradise poker]
 +
[http://www.totalvideogames.com/blog/playfreestrippoker/ play free strip poker]
 +
[http://www.totalvideogames.com/blog/eroticgames/ erotic games strip poker]
 +
[http://www.totalvideogames.com/blog/onlinepoker/ online poker calculator]
 +
[http://www.totalvideogames.com/blog/onlinepokertracker/ online poker tracker]
 +
[http://www.totalvideogames.com/blog/buydiazepam/ buy diazepam]
 +
[http://www.totalvideogames.com/blog/didrex/ didrex]
 +
[http://www.totalvideogames.com/blog/buydidrex/ buy didrex]
 +
[http://www.totalvideogames.com/blog/adipexpr/ adipex without prescription]
 +
[http://www.totalvideogames.com/blog/adipexp/ adipex p]
 +
[http://www.totalvideogames.com/blog/clonazepam/ clonazepam]
 +
[http://www.totalvideogames.com/blog/bclonazepam/ buy clonazepam]
 +
[http://www.totalvideogames.com/blog/diethylpropion/ diethylpropion]
 +
[http://www.totalvideogames.com/blog/celexa/ celexa]
 +
[http://www.totalvideogames.com/blog/paxilcr/ paxil cr]
 +
[http://www.totalvideogames.com/blog/lorazepam/ lorazepam]
 +
[http://www.totalvideogames.com/blog/hydrocodoneapap/ hydrocodone apap]
 +
[http://www.totalvideogames.com/blog/lortab/ lortab]
 +
[http://www.totalvideogames.com/blog/klonopin/ klonopin]
 +
[http://www.totalvideogames.com/blog/norco/ norco]
 +
[http://www.totalvideogames.com/blog/buypropecia/ buy propecia]
 +
[http://www.totalvideogames.com/blog/orderpropecia/ order propecia]
 +
[http://www.totalvideogames.com/blog/phendimetrazine/ phendimetrazine]
 +
[http://www.totalvideogames.com/blog/Butalbital/ Butalbital]
 +
[http://www.totalvideogames.com/blog/cheapxenical/ cheap xenical]
 +
[http://www.totalvideogames.com/blog/wellbutrinxl/ wellbutrin xl]
 +
[http://www.totalvideogames.com/blog/valtrex/ valtrex]
 +
[http://www.totalvideogames.com/blog/vicodin/ vicodin without prescription]
 +
[http://www.totalvideogames.com/blog/lasvegascasino/ las vegas casino coupons]
 +
[http://www.totalvideogames.com/blog/lasvegaspalms/ las vegas palms casino]
 +
[http://www.totalvideogames.com/blog/hooterscasinolas/ hooters casino las vegas]
 +
[http://www.totalvideogames.com/blog/microgamingcasino/ microgaming casino bonus]
 +
[http://www.totalvideogames.com/blog/playtechcasinobonu/ playtech casino bonus]
 +
[http://www.totalvideogames.com/blog/rtgcasinobonus/ rtg casino bonus]
 +
[http://www.totalvideogames.com/blog/grandcasinotunica/ grand casino tunica]
 +
[http://www.totalvideogames.com/blog/grandcasinomille/ grand casino mille lacs]
 +
[http://www.totalvideogames.com/blog/grandcasinocoushat/ grand casino coushatta]
 +
[http://www.totalvideogames.com/blog/grandcasinohinckle/ grand casino hinckley]
 +
[http://www.totalvideogames.com/blog/grandcasinohinkley/ grand casino hinkley]
 +
 +
 +
 +
</div>

Revision as of 21:11, 14 May 2006

Draft design for the vout rework effort

VoutReworkUserRequirements

VoutReworkOrganization

Overall architecture

The current system (one vout_thread_t per window) will be splitted

  • vout_core that manages all vout instances and windows. also takes care of vout_filters (wall, clone)
  • vout_window object per displayed window. provides a "region for vout_renderers" to draw in.
  • vout_render that renders the actual video, text and image

OSD and subpictures

We need to be able to display them either:

  • At video resolution, for DVD subtitles (on the "render")
  • At screen resolution (text subtitles, OSD control) (on the "output")
    • This will also allow us to draw subtitles outside of the video rendering
    • Probably needs specific code for each vout

At the moment, subpictures have very annoying timing constraints. subpictures should be timed either on the stream (for subpictures) or absolute, from the vout_core (for subfilters)

We should create two seperate systems. a vout_render level system which basically draws extra things into the region provided by vout_window. This can be both text, images and possibly even video. Material should be drawn in the resolution of the provided region, instead of the resolution of the main video. It should be seperate from the spu streams. However it should be possible to feed SPU based material to the vout_render system instead of the normal SPU stream pipeline and vice versa.

Comments from Gibalou: I agree overall but be aware that rendering on the vout window can be quite tricky. For instance on platforms which only support 1 overlay (already used by the video), we will have to constantly refresh the OSD (to handle resizing / refreshing of the vout window). For this reason I would suggest we keep this feature as simple as possible and only make it support displaying of subpictures (subpicture_t/subpicture_region_t).

Filters

Make a clean separation:

  • vout_filters should not be the same as real vouts anymore (will come from the split)

Comments from Gibalou: they don't really need to be changed since they alreday don't create any window.

  • pic_filter
    • Currently called video_filter2, should be renamed
    • Works on a single pic buffer
    • Can be streamed

Comments from Gibalou: video_filter2 is not just about 1->1 picture conversion. It is actually designed to work on video and could for instance allow for temporal de-interlacing, inverse telecine, etc... So it really is a video_filter and not merely a pic_filter.

Two big areas of work to be able to integrate video_filters into the vout core will be:

- Proper support for direct-rendering. Some filters won't actually modify the video frames directly (eg. auto-cropping) or will do in-place modifications so they will need to be able to allocate their pictures from the next filter in the chain and pass it on to the previous filter when requested. In short, picture allocation needs to be reviewed so it is done in an optimized way.

- Dynamic modification of the filter chain. Again this is tricky because the decoder (which does direct-rendering) will be using pictures allocated from the filter. If this filter changes or is removed, we will need a way replace the pictures in use by the decoder. That could be done by having a mechanism that progressively replaces the picture buffers used by the decoder by indirect buffers and when non of the direct buffers are in use anymore then we switch the filter. That will be a lot better then the current way of stopping/starting the decoder.

  • subpicture_filter

Modularization of specific calls

For many of the operations we need, OS specific calls exist (OpenGL, Quartz, DirectX). This should be modularized, with a native "C" fallback. OS specific calls are often faster.

There should be only one module for all the calls, if possible. The best module would be loaded by the vout_core singleton, and function pointers set up for each of the functions we need. perhaps a vout_Control type could take care of all these things in the vout_renderer. paramaters that should be handled this way are at least: alignment, AR, crop, pad

Comment from Gibalou: AR, crop (and soon pad) are already implemented in the vouts (see below). Alignment is also already supported and is only about placing the vout subwindow (frame or whatever you call it) into the main window.

Misc

  • Vout plugins (that provide vout windows) should allow reusing a vout by reusing it. This would much improve the experience)
  • Vout windows must have a flag to tell if they are "main" or "helper" (audio visualization, ...). Helper vouts should get no OSD (if another vout is present) and should not "steal" the accelerated vout"
  • cropping and padding (do at OS level, but provide a core call to set it up and configure) => Done
  • better hotkeys integration : need hotkey module redesign to act on selected vout and relevant input instead of the first we find
  • vout windows should indicate if they are on a 4:3 or 16:9 screen (we can calculate this trough resolution). Note that this can change, because a window could be moved from one screen to another. Use callbacks. => Why would you want to know the AR of the screen ? Aren't you confusing with the PAR ? This information could be used by the core to facilitate selection of cropping/padding etc for instance 4:3 display on a 16:9 screen. you might want to crop the top/bottom or stretch the view by default. Especially when you are also gonna add padding for subtitle rendering for instance, this information might become useful.

cropping padding functionality

  • add padding in order to display subs under the video. what if we have a 4:3 movie in a 4:3 screen? do we create blackbars to the left and right sides? do we crop a part of the video ???
  • 4:3 cropping to 16:9 (in order to remove blackbars at top and bottom
  • 16:9 cropping to 4:3 (in order to remove blackbars left and right side)
  • 4:3 to 16:9 (AR correction)
  • 16:9 to 4:3 (AR correction)
  • AR Freeform
  • Support Moviescreen AR? (2.39:1 or 1.85:1)
  • More info on AR: http://en.wikipedia.org/wiki/Aspect_ratio_(image)
  • If we let the window provider pass/calculate the AR of the display, then we can even do some of this automatically if the uses desires.
  • cropping should have priority over padding. Then we can first crop blackbars, then add padding for subs.
  • coordinate specified cropping and padding

Comment from Gibalou: AR / Cropping (and soon Padding) has already been reworked and is now handled directly in the vout module (makes sense since cropping and resizing are supported by most sane graphic APIs). All this is controled from the core by setting the relevant parameters in vout_format_t. Now, what could be done is to add extra logic (eg. in video_filters) to do some clever things like auto-cropping, etc... All they need to do is to modify video_format_t to change the final cropping/padding/AR.







[We are delicate. We do not delete your content.] [l_sp1]

ringtone maker verizon ringtone US Cellular Ringtone bcbg shoes waterford crystal swarovski crystal bead mesothelioma lawsuits mesothelioma symptoms mesothelioma diagnosis Sexy Prom Dresses Naturalizer Shoes Aero Bed Free Sprint Ringtones Free Verizon Ringtones free nextel ringtones sexy prom dress Formal Prom Dresses cheap prom dresses Plus Size Prom Dresses tiffany prom dresses erotic games strip poker pokemon trading card game rom hoyle card games teen bra Bra Teen Cleavage Micro Bikini Teens Bra sexy bras bulma bra sheer bra auto loan calculator Federal Student Loan Consolidation private student loan consolidation acs student loans countrywide home loans refinance home loan st louis wacoal bras teen bra unsecured signature loan Countrywide Home Loans Formal Prom Dresses Sexy Prom Dress cocktail dresses TMobile water softener tankless water heater oscar dresses mother of the bride dresses bridesmaid dresses cocktail dresses formal dresses easter dresses evening dresses evening gowns ball gowns formal gowns plus size wedding gowns rockport shoes reverse osmosis water filter merrell shoes casino royale throat pokers free strip poker crazy game of poker poker chips texas holdem poker game online poker aide online poker assistant casino directory gambling online online pai gow poker hooters casino atlantic city casinos buy ativan online buy oxycontin online buy alprazolam online buy alprazolam cialis no prescription xanax xr ultram er buy ultram online generic fioricet buy fioricet online phentermine 37 5mg bontril sr cheap bontril ambien cr buy didrex online adipex without a prescription buy tamiflu buy clonazepam purchase tramadol without a prescription buy acyclovir buy codeine private poker tournament freeroll poker tournament caribbean stud poker paradise poker play free strip poker erotic games strip poker online poker calculator online poker tracker buy diazepam didrex buy didrex adipex without prescription adipex p clonazepam buy clonazepam diethylpropion celexa paxil cr lorazepam hydrocodone apap lortab klonopin norco buy propecia order propecia phendimetrazine Butalbital cheap xenical wellbutrin xl valtrex vicodin without prescription las vegas casino coupons las vegas palms casino hooters casino las vegas microgaming casino bonus playtech casino bonus rtg casino bonus grand casino tunica grand casino mille lacs grand casino coushatta grand casino hinckley grand casino hinkley