<?php
function strimwidthCenter( $value, $length = 40 ) {
$valueEncoding = mb_detect_encoding( $value, 'auto', true );
if ( $length >= mb_strwidth( $value, $valueEncoding ) ) {
return $value;
}
$limited = '';
$firstWidth = ceil( $length/2 );
$secondStart = mb_strwidth( $value, $valueEncoding ) - ( $length - $firstWidth );
$secondWidth = $length - $firstWidth +1;
$limited = mb_strimwidth( $value, 0, $firstWidth, '...', $valueEncoding ) . mb_substr( $value, $secondStart, $secondWidth, $valueEncoding );
return $limited;
}
?>
mb_strimwidth
(PHP 4 >= 4.0.6, PHP 5)
mb_strimwidth — Get truncated string with specified width
Description
string mb_strimwidth
( string $str
, int $start
, int $width
[, string $trimmarker
[, string $encoding
]] )
Truncates string str to specified width .
Parameters
- str
-
The string being decoded.
- start
-
The start position offset. Number of characters from the beginning of string. (First character is 0)
- width
-
The width of the desired trim.
- trimmarker
-
A string that is added to the end of string when string is truncated.
- encoding
-
The encoding parameter is the character encoding. If it is omitted, the internal character encoding value will be used.
Return Values
The truncated string. If trimmarker is set, trimmarker is appended to the return value.
Examples
Example #1 mb_strimwidth() example
<?php
$str = mb_strimwidth($str, 0, 40, "..>");
?>
See Also
- mb_strwidth() - Return width of string
- mb_internal_encoding() - Set/Get internal character encoding
mb_strimwidth
CBieser
26-Aug-2008 05:50
26-Aug-2008 05:50
josiah dot ritchie at gmail dot com
13-Sep-2007 04:48
13-Sep-2007 04:48
While having the option to append a string to the end is nice, you can run into the problem of having a space between the append if the width is truncated after a space. I find something like this to be more attractive in the output, although messy in the code.
rtrim(mb_strimwidth($string, 0, 24))."..."
