static void add_subtitle( hb_list_t * list_subtitle, int position,
iso639_lang_t * lang, int lang_extension,
- uint32_t * palette )
+ uint32_t * palette, int style )
{
hb_subtitle_t * subtitle;
int ii, count;
break;
}
+ switch (style)
+ {
+ case HB_VOBSUB_STYLE_4_3:
+ strcat( subtitle->lang, " (4:3)" );
+ break;
+ case HB_VOBSUB_STYLE_WIDE:
+ strcat( subtitle->lang, " (Wide Screen)" );
+ break;
+ case HB_VOBSUB_STYLE_LETTERBOX:
+ strcat( subtitle->lang, " (Letterbox)" );
+ break;
+ case HB_VOBSUB_STYLE_PANSCAN:
+ strcat( subtitle->lang, " (Pan & Scan)" );
+ break;
+ }
+
hb_log( "scan: id=0x%x, lang=%s, 3cc=%s ext=%i", subtitle->id,
subtitle->lang, subtitle->iso639_2, lang_extension );
// Add Wide Screen subtitle.
pos = (spu_control >> 16) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette);
+ vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette,
+ HB_VOBSUB_STYLE_WIDE);
// permitted_df
// 1 - Letterbox not permitted
// Letterbox permitted. Add Letterbox subtitle.
pos = (spu_control >> 8) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette);
+ vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette,
+ HB_VOBSUB_STYLE_LETTERBOX);
}
if (!(vts->vtsi_mat->vts_video_attr.permitted_df & 2))
{
// Pan&Scan permitted. Add Pan&Scan subtitle.
pos = spu_control & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette);
+ vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette,
+ HB_VOBSUB_STYLE_PANSCAN);
}
}
else
{
pos = (spu_control >> 24) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette);
+ vts->vts_pgcit->pgci_srp[pgc_id-1].pgc->palette,
+ HB_VOBSUB_STYLE_4_3);
}
}
#include "dvdread/ifo_read.h"
#include "dvdread/nav_read.h"
+#define HB_VOBSUB_STYLE_4_3 0
+#define HB_VOBSUB_STYLE_WIDE 1
+#define HB_VOBSUB_STYLE_LETTERBOX 2
+#define HB_VOBSUB_STYLE_PANSCAN 3
+
struct hb_dvdread_s
{
char * path;
static void add_subtitle( hb_list_t * list_subtitle, int position,
iso639_lang_t * lang, int lang_extension,
- uint32_t * palette )
+ uint32_t * palette, int style )
{
hb_subtitle_t * subtitle;
int ii, count;
break;
}
+ switch (style)
+ {
+ case HB_VOBSUB_STYLE_4_3:
+ strcat( subtitle->lang, " (4:3)" );
+ break;
+ case HB_VOBSUB_STYLE_WIDE:
+ strcat( subtitle->lang, " (Wide Screen)" );
+ break;
+ case HB_VOBSUB_STYLE_LETTERBOX:
+ strcat( subtitle->lang, " (Letterbox)" );
+ break;
+ case HB_VOBSUB_STYLE_PANSCAN:
+ strcat( subtitle->lang, " (Pan & Scan)" );
+ break;
+ }
+
hb_log( "scan: id=0x%x, lang=%s, 3cc=%s ext=%i", subtitle->id,
subtitle->lang, subtitle->iso639_2, lang_extension );
// Add Wide Screen subtitle.
pos = (spu_control >> 16) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette);
+ ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette,
+ HB_VOBSUB_STYLE_WIDE);
// permitted_df
// 1 - Letterbox not permitted
// Letterbox permitted. Add Letterbox subtitle.
pos = (spu_control >> 8) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette);
+ ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette,
+ HB_VOBSUB_STYLE_LETTERBOX);
}
if (!(ifo->vtsi_mat->vts_video_attr.permitted_df & 2))
{
// Pan&Scan permitted. Add Pan&Scan subtitle.
pos = spu_control & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette);
+ ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette,
+ HB_VOBSUB_STYLE_PANSCAN);
}
}
else
{
pos = (spu_control >> 24) & 0x1F;
add_subtitle(title->list_subtitle, pos, lang, lang_ext,
- ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette);
+ ifo->vts_pgcit->pgci_srp[title_pgcn-1].pgc->palette,
+ HB_VOBSUB_STYLE_4_3);
}
}