首页
/ RichTextKit 1.2-b.1版本发布:原生类型支持与段落样式增强

RichTextKit 1.2-b.1版本发布:原生类型支持与段落样式增强

2025-07-05 18:05:01作者:裴锟轩Denise

RichTextKit是一个专注于富文本编辑的Swift框架,它为开发者提供了丰富的工具和组件来构建强大的文本编辑体验。在最新发布的1.2-b.1版本中,RichTextKit迈出了重要一步,开始转向更多地使用原生类型而非自定义类型,这一变化显著提升了框架的简洁性和功能性。

版本核心改进

本次更新的核心在于对NSParagraphStyle及其嵌套类型的全面支持。通过这一改进,开发者现在可以使用统一的函数、选择器、步进器和开关来获取、设置、选择、调整和切换以下段落样式属性:

  • 文本对齐(alignment)
  • 截断紧缩(allowsDefaultTighteningForTruncation)
  • 基础书写方向(baseWritingDirection)
  • 默认制表符间隔(defaultTabInterval)
  • 首行缩进(firstLineHeadIndent)
  • 头部缩进(headIndent)
  • 连字符因子(hyphenationFactor)
  • 换行模式(lineBreakMode)
  • 换行策略(lineBreakStrategy)
  • 行高倍数(lineHeightMultiple)
  • 行间距(lineSpacing)
  • 最大行高(maximumLineHeight)
  • 最小行高(minimumLineHeight)
  • 段落间距(paragraphSpacing)
  • 段落前间距(paragraphSpacingBefore)
  • 制表位(tabStops)
  • 尾部缩进(tailIndent)
  • 默认连字符使用(usesDefaultHyphenation)

技术细节解析

新增功能亮点

  1. 原生类型支持增强

    • 新增了NSMutableParagraphStyledefaultMutable构建器,简化了默认段落样式的创建
    • NSParagraphStyle添加了defaultPickerValues(for:)defaultStepperSteps(for:)函数,提供了标准的UI组件值范围
  2. 图标与默认值支持

    • NSParagraphStyle.KeyPath现在包含defaultIcon属性,为每种样式属性提供了直观的视觉表示
    • 新增的defaultPickerValuesdefaultStepperInterval属性为UI组件提供了合理的默认配置
  3. 文本对齐增强

    • NSTextAlignment新增了defaultIcon属性,能够动态生成表示不同对齐方式的图标
  4. 上下文与组件集成

    • RichTextContext新增了paragraphStyleValue(for:)paragraphStyleValueBinding(for:)函数,简化了段落样式的访问和绑定
    • RichTextViewComponent新增了基于键路径的样式操作函数,包括获取、设置和逐步调整样式值

视图组件增强

  1. 选择器(Picker)

    • 新增了基于段落样式值的初始化方法,支持快速创建针对特定样式属性的选择器
  2. 步进器(Stepper)

    • 新增了基于段落样式值的初始化方法,支持对数值型样式属性进行精确调整
  3. 开关(Toggle)

    • 新增了基于段落样式值的初始化方法,适用于布尔类型的样式属性

废弃内容说明

随着对原生类型支持的增强,框架中部分自定义类型已被标记为废弃:

  1. RichTextAlignment

    • 所有相关类型和功能已被废弃,建议使用原生的NSTextAlignment和相关段落样式功能替代
  2. RichTextLine

    • 所有相关类型和功能已被废弃,新的段落样式功能提供了更全面的行相关属性控制

技术意义与优势

这一版本的改进带来了几个显著优势:

  1. 代码精简

    • 通过使用原生类型替代自定义类型,框架代码量显著减少,同时功能更加强大
  2. 一致性提升

    • 统一的API设计使得不同样式属性的操作方式保持一致,降低了学习成本
  3. 扩展性增强

    • 基于键路径的设计使得未来添加对新样式属性的支持更加容易
  4. 性能优化

    • 直接使用原生类型减少了类型转换开销,提升了运行效率

对于开发者而言,这些改进意味着能够以更简洁的代码实现更丰富的文本编辑功能,同时获得更好的性能和更一致的开发体验。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
260
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
854
505
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
254
295
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
21
5