UIViewController в SwiftUI - PullRequest
       12

UIViewController в SwiftUI

0 голосов
/ 03 ноября 2019

Я создаю новостные приложения. Эта статья в формате .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.

Спасибо за вашу помощь.

...