CoreTextToy
This is a small test project for iOS CoreText related experimentation.
License
This code is licensed under the 2-clause BSD license ("Simplified BSD License" or "FreeBSD License") license. The license is reproduced below:
Copyright 2011 Jonathan Wight. All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
-
Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY JONATHAN WIGHT ''AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JONATHAN WIGHT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
The views and conclusions contained in the software and documentation are those of the authors and should not be interpreted as representing official policies, either expressed or implied, of Jonathan Wight.
Automatic Reference Counting (ARC)
The source code in this repository uses Automatic Reference Counting. Older, non-ARC source code may exist in a "feature/nonARC" maintenance branch.
CMarkupValueTransformer
A value transformer capable of converting simple HTML into a NSAttributedString. At the moment it only supports "b" and "i" tags (in any valid, nested combinations) but that is quite easy to expand. Each tag combination can have their set of attributes.
UIFont_CoreTextExtensions
Extension on UIFont to get a CTFont and to get bold/italic, etc versions of the font. Scans the font name to work out the attributes of a particular font. This code is crude and effective - but needs to be tested on all iOS font names (esp. the weirder ones).
CCoreTextLabel
Beginning of a UILabel workalike that uses CoreTest to render NSAttributedString objects.
CCoreTextRenderer
The rendering class that takes NSAttributedStrings and some other parameters and renders them into the current CGContext.
FAQ
Why does this even exist? Why not just use UIWebView?
UIWebViews are expensive to create and are pretty much overkill when all you need is a simple UILabel type class that shows static styled text.
https://github.com/Cocoanetics/NSAttributedString-Additions-for-HTML
Why does this even exist? Why not just useCCoreTextLabel is designed simply to show static text on screen, akin to UILabel. "NSAttributedString-Additions-for-HTML" seems to do a lot of things that I just dont need.
How much HTML does this thing support?
It uses a minimal subset of HTML. In fact don't think of it as pure HTML - think of it as just a convenient method for creating NSAttributedString
Only a handful of tags are supported right now, but you can define your own quite easily.
Link and image tags are now supported.
The following tags are supported
- <br>
- <b>
- <a>
- <i>
- <mark>
- <strike>
- <img>
So how do I get HTML into CCoreTextLabel?
The quick way:
NSString *theMarkup = @"<b>Hello world</b>";
NSError *theError = NULL;
NSString *theAttributedString = [NSAttributedString attributedStringWithMarkup:theMarkup error:&theError];
// Error checking goes here.
self.label.text = theAttributedString;
For the long way see "How do I add custom styles?"
How do I add custom styles?
// Here's the markup we want to put into our. Note the custom <username> tag
NSString *theMarkup = [NSString stringWithFormat:@"<username>%@</username> %@", theUsername, theBody];
NSError *theError = NULL;
// Create a transformer and give it a default font.
CMarkupValueTransformer *theTransformer = [[CMarkupValueTransformer alloc] init];
theTransformer.standardFont = [UIFont systemFontOfSize:13];
// Create custom attributes for our new "username" tag
NSDictionary *theAttributes = [NSDictionary dictionaryWithObjectsAndKeys:
(__bridge id)[UIColor blueColor].CGColor, (__bridge NSString *)kCTForegroundColorAttributeName,
(__bridge id)[theTransformer.standardFont boldFont].CTFont, (__bridge NSString *)kCTFontAttributeName,
NULL];
[theTransformer addStyleAttributes:theAttributes forTagSet:[NSSet setWithObject:@"username"]];
// Transform the markup into a NSAttributedString
NSAttributedString *theAttributedString = [theTransformer transformedValue:theMarkup error:&theError];
// Give the attributed string to the CCoreTextLabel.
self.label.text = theAttributedString;
TODO
- See github bug list.
TODO (DONE)
- Support img tags.
- Support basic CSS styling (changing colour of text perhaps)
- Support links
- Support tags like "p" &
"br"that don't style the text but do control flow (br is now implemented) - Support HTML entities
- Support tags with attributes. This is important for the "a" tag.