Skip to content

Instantly share code, notes, and snippets.

@peterhry
Created February 18, 2013 18:14
Show Gist options
  • Save peterhry/4979378 to your computer and use it in GitHub Desktop.
Save peterhry/4979378 to your computer and use it in GitHub Desktop.
A CodePen by peterhry. Curved Text - An improvement on this approach: http://css-tricks.com/set-text-on-a-circle/ In this case the character widths are calculated so that you don't need to use a monospaced font.
<span id="curved">Here is some hot curved text. It goes all the way around.</span>
<span id="curved2">Here it is going the other way. What do you think?</span>
/*global jQuery */
/*!
* ElipText.JS 0.1
*
* Copyright 2013, Peter Hrynkow http://peterhrynkow.com
* Released under the WTFPL license
* https://github.com/peterhry/ElipText
* http://sam.zoy.org/wtfpl/
*
*
* Date: Sun Feb 17
*/
$.fn.elipText = function(options) {
var settings = {
'radius' : 200,
dir: 1
};
if (typeof($.fn.lettering) !== 'function') {
console.log('Lettering.js is required');
return;
}
return this.each(function () {
if (options) {
$.extend(settings, options);
}
var elem = $(this),
txt = elem.html().replace(/\s/g, '&nbsp;');
elem.html(txt).lettering();
var offset = 0,
origin = 'center ' + (settings.radius) + 'px',
delta = (180 / Math.PI),
ch = parseInt(elem.find('span').css('line-height'), 10);
if (settings.dir===-1) {
origin = 'center ' + (-settings.radius + ch) + 'px';
}
elem.find('span').each(function () {
var l = $(this);
offset += l.outerWidth() / 2 / (settings.radius-ch) * delta;
l.data('rot', offset);
offset += l.outerWidth() / 2 / (settings.radius-ch) * delta;
});
elem.find('span').each(function () {
var l = $(this),
r = (-offset * settings.dir / 2) + l.data('rot') * settings.dir,
transform = 'rotate(' + r + 'deg)';
l.css({
top: 0,
left: '50%',
marginLeft: -l.width() / 2,
position: "absolute",
//
webkitTransform: transform,
MozTransform: transform,
oTransform: transform,
msTransform: transform,
transform: transform,
//
webkitTransformOrigin: origin,
MozTransformOrigin: origin,
oTransformOrigin: origin,
msTransformOrigin: origin,
transformOrigin: origin
});
});
});
};
$('#curved').elipText({radius: 220});
$('#curved2').elipText({radius: 160, dir:-1});
html,body {
width: 100%;
height: 100%;
font: 32px/1.4 georgia, arial;
letter-spacing: 0;
}
#curved {
position: absolute;
left: 20%;
top: 5%;
}
#curved2 {
position: absolute;
left: 60%;
bottom: 15%;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment