Я создаю новостные приложения. Эта статья в формате .txt / .html / .md, поэтому я создал программу чтения уценок в UIKit. Я создал его в новом Xcode Single View Project, и это мой код:
[enter link description here][1]
import UIKit
import markymark
class AdvancedMarkdownViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
let scrollView = UIScrollView()
let markDownView = getMarkDownView()
scrollView.isScrollEnabled = false
view.addSubview(scrollView)
scrollView.addSubview(markDownView)
let views: [String: Any] = [
"view": view,
"scrollView": scrollView,
"markDownView": markDownView
]
scrollView.translatesAutoresizingMaskIntoConstraints = false
markDownView.translatesAutoresizingMaskIntoConstraints = false
var constraints: [NSLayoutConstraint] = []
constraints += NSLayoutConstraint.constraints(withVisualFormat: "V:|[scrollView]|", options: [], metrics: [:], views: views)
constraints += NSLayoutConstraint.constraints(withVisualFormat: "H:|[scrollView]|", options: [], metrics: [:], views: views)
constraints += NSLayoutConstraint.constraints(withVisualFormat: "H:|[markDownView(==scrollView)]|", options: [], metrics: [:], views: views)
constraints += NSLayoutConstraint.constraints(withVisualFormat: "V:|[markDownView]|", options: [], metrics: [:], views: views)
view.addConstraints(constraints)
}
}
private extension AdvancedMarkdownViewController {
func getMarkDownView() -> UIView {
// Parsing to MarkDownItem's
let markDownString = getMarkDownString()
let markyMark = MarkyMark(build: {
// Choose flavor (set of rules)
$0.setFlavor(ContentfulFlavor())
//Example: Add single custom rules
//$0.addRule(CustomHeaderRule())
})
let markDownItems = markyMark.parseMarkDown(markDownString)
// Configure styling, see README for more styling options or Implement your own Styling object instead of DefaultStyling.
let styling = DefaultStyling()
styling.listStyling.bulletImages = [
UIImage(named: "circle"),
UIImage(named: "emptyCircle"),
UIImage(named: "line"),
UIImage(named: "square")
]
styling.headingStyling.contentInsetsForLevels = [
UIEdgeInsets(top: 16, left: 6, bottom: 15, right: 10), // H1
UIEdgeInsets(top: 5, left: 0, bottom: 5, right: 10) // H2, ...
]
styling.headingStyling.textColorsForLevels = [
.label, // H1
.label, // H2
.secondaryLabel, // H3
.tertiaryLabel // H4, ...
]
// Only uppercase H1 headers
styling.headingStyling.capitalizationForLevels = [
nil //H1, ...
]
styling.headingStyling.fontsForLevels = [
UIFont.preferredFont(forTextStyle: .largeTitle), //H1
UIFont.preferredFont(forTextStyle: .title1), //H2
UIFont.preferredFont(forTextStyle: .title2), //H3
UIFont.preferredFont(forTextStyle: .title3), //H4
UIFont.preferredFont(forTextStyle: .headline), //H5
UIFont.preferredFont(forTextStyle: .footnote), //H6
]
styling.headingStyling.isBold = true
// Link
styling.linkStyling.textColor = .systemBlue
styling.linkStyling.baseFont = nil // Default: nil. Setting baseFont to nil will inherit font from paragraphStyling
styling.linkStyling.isBold = false
styling.linkStyling.isItalic = true
styling.linkStyling.isUnderlined = false
//image
styling.imageStyling.contentInsets.left = 20
styling.imageStyling.contentInsets.right = 20
//paragraph
styling.paragraphStyling.textColor = .label
// HorizonLinesStyling
styling.horizontalLineStyling.backgroundColor = UIColor.secondaryLabel
styling.horizontalLineStyling.contentInsets.left = 20
styling.horizontalLineStyling.contentInsets.right = 20
let configuration = MarkdownToViewConverterConfiguration(styling: styling)
let converter = MarkDownConverter(configuration: configuration)
// Converter hook, only meant for very specific (otherwise impossible) usecases. The hook is triggered every time a MarkdownItem is converted to a view.
// In this example the headers are rotated, which is normally not supported in MarkyMark styling.
/**
converter.didConvertElement = {
markdownItem, view in
// When a header is converted and it's H1, rotate it slighly for example
if let headerMarkDownItem = markdownItem as? HeaderMarkDownItem, headerMarkDownItem.level == 1 {
view.transform = CGAffineTransform(rotationAngle: -0.07)
}
}
*/
return converter.convert(markDownItems)
}
func getMarkDownString() -> String {
var markdownString: String = ""
if let filepath = Bundle.main.path(forResource: "markdown", ofType: "txt") {
markdownString = try! String(contentsOfFile: filepath)
}
return markdownString
}
}
И вот результат: Vidéo
После того, как я попробовалчтобы добавить его в мой основной проект написал в SwiftUI avec struct.
struct ViewControllerBISController : UIViewControllerRepresentable {
func makeUIViewController(context: UIViewControllerRepresentableContext<ViewControllerBISController>) -> AdvancedMarkdownViewController {
return AdvancedMarkdownViewController()
}
func updateUIViewController(_ uiViewController: AdvancedMarkdownViewController, context: UIViewControllerRepresentableContext<ViewControllerBISController>) {
}
}
Но у меня есть небольшой прямоугольник, когда я встраиваю его в мой код Это результат Я бы хотел, чтобы высота анализатора уценок в моем быстром представлении пользовательского интерфейса равняласьвысота моего файла уценки. Но я не хочу иметь свиток в моем представлении уценки, потому что у меня уже есть свиток в моем быстром представлении UI.
Спасибо за вашу помощь.