Grigori Goronzy [Thu, 21 Jan 2010 05:31:45 +0000 (06:31 +0100)]
Skip border generation if glyph is collapsed
If a character is completely collapsed in x or y direction (\fscx0,
\fscy0), the rasterizer will not generate any visible pixels. This also
means vsfilter will never draw any border in this case, since it works
on the pixel data. FreeType's stroker OTOH happily draws a border around
a character, no matter how collapsed it is. Emulate vsfilter's behavior
by skipping border generation if the glyph is collapsed.
Grigori Goronzy [Mon, 18 Jan 2010 23:42:22 +0000 (00:42 +0100)]
Up size limit for script files
Change size limit from 10MB to 50MB and clean up code a bit. A limit
still might be handy if one selects a very big file for subtitles by
accident. 50MB should be enough for even the biggest karaoke files.
Grigori Goronzy [Wed, 6 Jan 2010 22:51:01 +0000 (23:51 +0100)]
Improve rotation cache accuracy
In some cases 16.16 precision is not good enough. Instead use 10.22 and
use modulo 360.0 on the angles to make overflows impossible and improve
cache hit ratio sometimes.
Grigori Goronzy [Mon, 4 Jan 2010 18:54:19 +0000 (19:54 +0100)]
Reset clip_mode on new events
Make sure that the clip mode is reset to regular on new events.
Otherwise events after an event that used inverse clip will also use
inverse clip. Ouch! Usually the symptom is that subtitles become
invisible as the whole screen is clipped.
Grigori Goronzy [Sun, 3 Jan 2010 13:54:02 +0000 (14:54 +0100)]
Replace strtod with locale-independent strtod
strtod respects the locale and in some locales, the decimal separator is
not a point, leading to parsing errors in tags like \pos(23.4,5), which
are perfectly valid.
As there isn't a really portable way to use a particular locale just for
one call to strtod, reimplement it. The implementation was taken from
the 1.8 branch of Ruby.
Grigori Goronzy [Sun, 11 Oct 2009 07:07:26 +0000 (09:07 +0200)]
Fix libass w/o fontconfig
Make sure that libass does not crash even if no default font is
provided. Additionally, fix crashes related to drawings in this and
possibly other unusual cases.
Document the default_path and default_family parameters of
ass_set_fonts.
Grigori Goronzy [Thu, 10 Sep 2009 02:47:21 +0000 (04:47 +0200)]
Render NBSP (\h) as normal space
Many fonts don't have a non-breaking space (NBSP) character and this
can cause problems when these glyphs are substituted. Render them
like a regular space.
Grigori Goronzy [Tue, 8 Sep 2009 20:21:43 +0000 (22:21 +0200)]
Disable kerning by default and make it configurable
Kerning causes problems with many (broken) fonts. VSFilter doesn't use
kerning so these problems won't be apparant, while libass uses kerning
by default.
For compatibility reasons, disable kerning by default. In addition,
make it configurable through style overrides and the Script Info
header.
I.e. put "Kerning: yes" into the Script Info header to enable kerning.
With MPlayer, using "-ass-force-style Kerning=yes" will always
enable kerning.
This also includes a minor ABI change for tracking the kerning boolean.
As this only affects code that creates or modifies ASS_Tracks manually,
and I'm not aware of anyone doing that, the SONAME will not be bumped.
Grigori Goronzy [Tue, 1 Sep 2009 00:22:44 +0000 (02:22 +0200)]
Revert "Merge glyph and outline bitmap better"
This reverts commit d3cd5b0148d64ae0f6e288e69b09acfe639fdcce.
This hack improved blending in few situations, but at the same time
broke it in lots o others; get rid of it.
Grigori Goronzy [Mon, 31 Aug 2009 00:52:03 +0000 (02:52 +0200)]
Calculate glyph slant width correctly
If a glyph is wider than its advance width for italic to non-italic
style changes, assume it was obliqued by FreeType's FT_GlyphSlot_Oblique
function and offset the next glyph accordingly.
Grigori Goronzy [Sat, 29 Aug 2009 18:26:20 +0000 (20:26 +0200)]
Do not close empty drawings
If there are no points (i.e. illegal drawing), do not close the drawing
by incrementing the contour counter. Under certain circumstances, this
can crash the FreeType stroker.
Grigori Goronzy [Sun, 23 Aug 2009 14:33:38 +0000 (16:33 +0200)]
Fix opaque box sizing again
Another try to get it to work like in VSFilter. Hopefully it's
behaving the same now (except in some cases, since VSFilter layouts
word-based, but libass is glyph-based).
Additionally, make sure horizontal letter spacing (\fsp) is scaled
according to ScaleX.
Grigori Goronzy [Sun, 23 Aug 2009 01:49:22 +0000 (03:49 +0200)]
Fix glyph overlap blending
Use the bitmap pointer for the cache hash key. This preserves the
blending history, which fixes occasional corruptions due to previous
replacements not being dealt with correctly. It also simplifies the
hash key a lot and thus speeds up cache lookups.
Additionally, change the blending equation from max(a, b) to min(a + b,
0xff), i.e. a saturating addition. Usually this looks a lot better.
Grigori Goronzy [Thu, 20 Aug 2009 14:41:11 +0000 (16:41 +0200)]
Clip vector blending: do not copy last row padding
Do not copy the padding on the last row into the new buffer since we
cannot rely on the padding actually existing; might fix a segfault in
some obscure cases.
Grigori Goronzy [Thu, 20 Aug 2009 02:36:47 +0000 (04:36 +0200)]
Adjust shearing behavior to match VSFilter
Make horizontal shearing (\fax) shear from top to bottom of a glyph;
scale shearing factors with horizontal and vertical scaling factors.
This makes the shearing operations similar to VSFilter, except for
\fay in some cases, but this is not unexpected. Vertical shearing
is implemented different on purpose.
Grigori Goronzy [Wed, 19 Aug 2009 21:10:24 +0000 (23:10 +0200)]
VSFilter quirk: double-scale widths of opaque boxes
VSFilter double-scales the widths of the opaque box in X direction,
which gives much wider boxes than expected (or much less wider boxes)
if ScaleX != 100. Emulate this behavior, even if it is unbelievably
stupid and no doubt a bug in VSFilter.
Grigori Goronzy [Sat, 15 Aug 2009 01:31:52 +0000 (03:31 +0200)]
Improve and fix outline striker
Exit early if no striking is needed; make sure to strike in reverse
direction for non-truetype font and use the usual return value
convention (0 == no errors).
Grigori Goronzy [Wed, 12 Aug 2009 23:08:22 +0000 (01:08 +0200)]
Use event bbox for collision detection
Consider the bounding box of an event for collision detection instead
of only its vertical position and height. This allows multiple events
per line if they don't overlap.
Grigori Goronzy [Wed, 12 Aug 2009 04:20:26 +0000 (06:20 +0200)]
Always parse colors as hex for ASS tracks
According to the ASS specification, colors can only be specified in hex.
Modify the color parsing accordingly; this especially means that colors
where the hex sigil (the "H") is missing can now be parsed.
Grigori Goronzy [Wed, 12 Aug 2009 03:26:55 +0000 (05:26 +0200)]
Add glyph emboldening fallback
Fallback to embolden manually with FreeType in case a bold face was
requested, but no bold variant is available. The glyphs are slightly
emboldened (much less than FT_GlyphSlot_Embolden would do) and the
metrics are not touched at all.
Grigori Goronzy [Wed, 12 Aug 2009 03:07:13 +0000 (05:07 +0200)]
Fix italic to non-italic space handling
Scan backwards in the glyph array for a glyph with some actual points
when correctin glyph spacing after italic to non-italic style changes.
This is mostly useful in case a space ends italicized text.
Grigori Goronzy [Wed, 12 Aug 2009 01:43:46 +0000 (03:43 +0200)]
Support \q override tag
Parse \q override tag and set a new state variable to its value.
The line wrapping code still needs improvements; wrap style 0/3 are not
entirely correctly implemented and style 1 is not implemented.
Grigori Goronzy [Wed, 12 Aug 2009 00:59:00 +0000 (02:59 +0200)]
Implement BorderStyle 3
The "opaque box" border style renders an opaque box in the glyph area
instead of rendering a regular stroked border. This implementation
replaces the glyph outline by an outline that contains only one
rectangle with the size of the glyph, plus optional extra border.
Grigori Goronzy [Tue, 11 Aug 2009 23:45:39 +0000 (01:45 +0200)]
Fix advance for italic to non-italic style changes
After a italic to non-italic style change the space between the glyphs
is sometimes wrongly calculated, especially if the font doesn't have
an italic version and FreeType falls back to oblique glyphs.
In such cases, add additional space to the glyph's advance to make up
for the slant of the glyph; the amount is calculated from the glyph's
bbox.
Grigori Goronzy [Thu, 6 Aug 2009 11:04:20 +0000 (13:04 +0200)]
Rename typedefs (breaks API)
Rename all typedefs from the convention foo_bar_t, which can possibly
conflict with POSIX types, to FooBar (and ASS_FooBar for public
API typedefs). Fix formatting and stray comments while at it.
Grigori Goronzy [Wed, 29 Jul 2009 19:33:29 +0000 (21:33 +0200)]
Do not round karaoke timing coordinates
Do not round the coordinates of the glyph bbox (when converting 26.6
fixed-point to integer); they are used for timing karaoke. Doing so
can sometimes make \k and \ko karaoke not apply correctly.
Grigori Goronzy [Tue, 28 Jul 2009 09:05:26 +0000 (11:05 +0200)]
Fix \k and \ko tags
The timing calculations for \k and \ko were off and still assumed
int values for a bbox, while it now uses a d6 representation.
This essentially made duration about 64 times as long as it should be.
Grigori Goronzy [Sun, 26 Jul 2009 14:03:37 +0000 (16:03 +0200)]
Improve message callback API
Instead of passing a pointer to a va_list, pass the va_list itself.
Additionally, use const char for the format string and use names in
the prototype that describe the arguments' meaning.
Grigori Goronzy [Sat, 25 Jul 2009 01:59:58 +0000 (03:59 +0200)]
Remove shift vector in ass_render_event
The shift is not calculated when fetching a glyph anymore. Instead,
it is calculated right before rasterizing a glyph. Remove the
shift vector and make get_outline_glyph, the glyph cache and
ass_font_set_transform work without supplying a shift vector.
Grigori Goronzy [Fri, 24 Jul 2009 08:01:41 +0000 (10:01 +0200)]
Fix fontconfig memory leaks
Do not manually use FcConfigFilename; passing a NULL pointer to
FcConfigParseAndLoad is just as effective and also avoids a memory leak
since the string allocated by FcConfigFilename was never freed.
Free FcConfig instance in fontconfig_done; since we're not using the
default configuration anymore it doesn't make sense to keep the
configuration around.
Grigori Goronzy [Wed, 22 Jul 2009 20:49:55 +0000 (22:49 +0200)]
Fallback to default fontconfig configuration
If parsing or loading the fontconfig configuration file, either
using the default or a specified one, fails, try to load the
default fontconfig configuration. This triggers loading a fallback
configuration if no configuration file is available at all. A warning
message is emitted to notify the user about this.
Grigori Goronzy [Wed, 22 Jul 2009 01:24:42 +0000 (03:24 +0200)]
Fix rasterizer error handling (double free)
In case rasterizing a glyph is successful, but rasterizing its outline
is not, do not free the glyph bitmap. It will be freed in cache cleanup
later. Freeing it earlier leads to a double free.
Grigori Goronzy [Wed, 22 Jul 2009 01:21:33 +0000 (03:21 +0200)]
Bold/italic: interpret -1 as "true"
Interpret the value -1 as "true", as specified in the ASS
specifications. Otherwise, clamp the value to 0 for other values <
0, so these are interpreted as "false".
Grigori Goronzy [Tue, 21 Jul 2009 01:06:05 +0000 (03:06 +0200)]
Factor out bitmap buffer copy
For clarity, factor out bitmap copying into a function. Do not pad the
bitmap with stride in the last row; this can not by guaranteed anyway.
Add a comment about this peculiarity to the API documentation in ass.h
Idea by Evgeniy Stepanov.
Grigori Goronzy [Mon, 20 Jul 2009 22:04:24 +0000 (00:04 +0200)]
Animations: allow equal start and end time
Do not set the end time of the animation to the end time of the event
in case end time and start time specified in a \t tag are equal.
This should sort out a problem introduced by commit 1f176b.