아미(아름다운미소)

swift [File] 버튼 구현하기 본문

랭귀지/SWIFT

swift [File] 버튼 구현하기

유키공 2018. 1. 28. 13:30

- 웹 뷰로 간단한 웹 브라우져 만들기 6

html 파일을 프로젝트에 추가하고 [File] 버튼을 클릭하면 이 Html 파일이 웹 뷰에 나타나도록 구현 합니다.

<html>

    <head>

        <meta charset="utf-8">

    </head>

    <body>

        <H3>HTML FILE</H3>

        html 파일을 이용한 웹페이지<BR />

        <a href="http://www.todaymart.com">아름다운 미소 블로그</a>로 이동

    </body>

</html>


 위치

 btnLoadHtmlString 함수 아래

 연결(Connection)

 Action

 이름(Name)

 btnLoadHtmlFile

 유형(Type)

 UIButton 


    @IBAction func btnLoadHtmlFile(_ sender: UIButton) {

        //Bundle에서 main으로 변수를 생성 합니다.

        let myHtmlBundle = Bundle.main

        //path 함수를 호출합니다.

        let filepath = myHtmlBundle.path(forResource: "htmlView", ofType: "html")

        //html 파일을 로딩합니다.

        loadWebPage(filepath!)

    }


import UIKit
//webViewDidStartLoad, webViewDidFinishLoad 함수를 
//사용하기 위하여 UIWebViewDelegate를 상속 받습니다.
class ViewController: UIViewController, UIWebViewDelegate {

    @IBOutlet weak var txtUrl: UITextField!
    @IBOutlet weak var myWebView: UIWebView!
    @IBOutlet weak var myActivityindicator: UIActivityIndicatorView!
    
    func loadWebPage(_ url: String) {
        //상수 myUrl은 url 값을 받아 URL형으로 선언합니다.
        let myUrl = URL(string: url)
        //상수 myRequest는 상수 myUrl을 받아 URLRequest형으로 선언합니다.
        let myRequest = URLRequest(url: myUrl!)
        //UIWebView형의 myWebView 클래스의 loadRequest 메서드를 호출합니다.
        myWebView.loadRequest(myRequest)
    }
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        //myWebView 의 delegate 를 self 로 추가 합니다.
        myWebView.delegate = self
        //앱이 처음 나타나면 접속할 웹 페이지 주소를 추가 합니다.
        loadWebPage("http://www.todaymart.com")
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    
    func webViewDidStartLoad(_ webView: UIWebView) {
       //액티비티 인디케이터 동작을 시작하는 함수
        myActivityindicator.startAnimating()
    }
    
    func webViewDidFinishLoad(_ webView: UIWebView) {
       ////액티비티 인디케이터 동작을 종료하는 함수
        myActivityindicator.stopAnimating()
    }

    @IBAction func btnGoUrl(_ sender: UIButton) {
    }
    
    //Site1 버튼 클릭하면 이동하는 페이지
    @IBAction func btnGoSite1(_ sender: UIButton) {
        loadWebPage("http://m.naver.com")
    }
    //Site2 버튼을 클릭하면 이동하는 페이지
    @IBAction func btnGoSite2(_ sender: UIButton) {
        loadWebPage("http://m.daum.net")
    }
    
    @IBAction func btnLoadHtmlString(_ sender: UIButton) {
       //html 문을 변수에 저장합니다.
        let htmlString = "

Html String

String 변수를 이용한 웹 페이지
아미(아름다운미소)로 이동" //loadHTML String 함수를 이용하여변수에 저장된 HTML문을 웹 부에 표시합니다. myWebView.loadHTMLString(htmlString, baseURL: nil) } @IBAction func btnLoadHtmlFile(_ sender: UIButton) { //Bundle에서 main으로 변수를 생성 합니다. let myHtmlBundle = Bundle.main //path 함수를 호출합니다. let filepath = myHtmlBundle.path(forResource: "htmlView", ofType: "html") //html 파일을 로딩합니다. loadWebPage(filepath!) } @IBAction func btnStop(_ sender: UIBarButtonItem) { //웹 페이지의 로딩을 중지시키는 함수를 호출합니다. myWebView.stopLoading() } @IBAction func btnReload(_ sender: UIBarButtonItem) { //웹 페이지를 재로딩시키는 함수를 호출합니다. myWebView.reload() } @IBAction func btnGoBack(_ sender: UIBarButtonItem) { //이전 웹 페이지로 이동시키는 함수를 호출합니다. myWebView.goBack() } @IBAction func btnGoForward(_ sender: UIBarButtonItem) { //다음 웹 페이지로 이동시키는 함수를 호출합니다. myWebView.goForward() } }

[결과화면]

[HTML] 버튼을 클릭하면 미리 만들어 놓은 HTML파일의 내용이 적용된 것을 확인할수 있습니다.


html file



Comments