This commit is contained in:
Horis
2023-10-01 23:45:47 +08:00
parent f8e555218c
commit 318ff762fa
2 changed files with 19 additions and 7 deletions

View File

@@ -15,17 +15,20 @@ class ZhLayout(
textPaint: TextPaint,
width: Int
) : Layout(text, textPaint, width, Alignment.ALIGN_NORMAL, 0f, 0f) {
companion object {
private val postPanc = hashSetOf(
"", "", "", "", "", "", "", "", "", "", "}",
"", ")", ">", "]", "}", ",", ".", "?", "!", ":", "", "", ";"
)
private val prePanc = hashSetOf("", "", "", "", "", "", "(", "<", "[", "{", "")
}
private val defaultCapacity = 10
var lineStart = IntArray(defaultCapacity)
var lineWidth = FloatArray(defaultCapacity)
private var lineCount = 0
private val curPaint = textPaint
private val cnCharWitch = getDesiredWidth("", textPaint)
private val postPanc = hashSetOf(
"", "", "", "", "", "", "", "", "", "", "}",
"", ")", ">", "]", "}", ",", ".", "?", "!", ":", "", "", ";"
)
private val prePanc = hashSetOf("", "", "", "", "", "", "(", "<", "[", "{", "")
enum class BreakMod { NORMAL, BREAK_ONE_CHAR, BREAK_MORE_CHAR, CPS_1, CPS_2, CPS_3, }
class Locate {
@@ -42,7 +45,10 @@ class ZhLayout(
var line = 0
val widthsArray = FloatArray(text.length)
curPaint.getTextWidths(text as String, widthsArray)
val (words, widths) = ChapterProvider.getStringArrayAndTextWidths(text, widthsArray.asList())
val (words, widths) = ChapterProvider.getStringArrayAndTextWidths(
text,
widthsArray.asList()
)
var lineW = 0f
var cwPre = 0f
var length = 0
@@ -111,26 +117,31 @@ class ZhLayout(
lineStart[line + 1] = length
breakCharCnt = 1
}
BreakMod.BREAK_ONE_CHAR -> {//模式1 当前行下移一个字
offset = cw + cwPre
lineStart[line + 1] = length - words[index - 1].length
breakCharCnt = 2
}
BreakMod.BREAK_MORE_CHAR -> {//模式2 当前行下移多个字
offset = cw + cwPre
lineStart[line + 1] = length - breakLength
breakCharCnt = breakIndex + 1
}
BreakMod.CPS_1 -> {//模式3 两个后置标点压缩
offset = 0f
lineStart[line + 1] = length + s.length
breakCharCnt = 0
}
BreakMod.CPS_2 -> { //模式4 前置标点压缩+前置标点压缩+字
offset = 0f
lineStart[line + 1] = length + s.length
breakCharCnt = 0
}
BreakMod.CPS_3 -> {//模式5 前置标点压缩+字+后置标点压缩
offset = 0f
lineStart[line + 1] = length + s.length

View File

@@ -148,13 +148,14 @@ object UrlUtil {
}
}
private val fileSuffixRegex = Regex("^[a-z\\d]+$", RegexOption.IGNORE_CASE)
/* 获取合法的文件后缀 */
fun getSuffix(str: String, default: String? = null): String {
val suffix = CustomUrl(str).getUrl()
.substringAfterLast(".", "")
.substringBefore("?")
//检查截取的后缀字符是否合法 [a-zA-Z0-9]
val fileSuffixRegex = Regex("^[a-z\\d]+$", RegexOption.IGNORE_CASE)
return if (suffix.length > 5 || !suffix.matches(fileSuffixRegex)) {
AppLog.put("Cannot find legal suffix:\n target: $str\n suffix: $suffix")
default ?: "ext"