Set Minimum and Maximum Zoom on WKWebView or Disabling it entirely










0















What I want:



I'm trying to figure out how to set the minimum and maximum zoom onWKWebView.
I've searched through a lot of people who asked similar questions but no solutions has worked in my code.
If there is no option to set the minimum and maximum zoom, I would like to know how to disable zoom on WKWebView entirely.



 import UIKit
import WebKit

class CalendarViewController: UIViewController, WKNavigationDelegate, WKUIDelegate

var webView: WKWebView!
@IBOutlet weak var containerView: UIView!
@IBOutlet weak var progressView: UIProgressView!

override func loadView()
super.loadView()


override func viewDidLoad()
super.viewDidLoad()


progressView.setProgress(0.1, animated: true)

let webConfiguration = WKWebViewConfiguration()
webConfiguration.applicationNameForUserAgent = "Version/8.0.2 Safari/600.2.5"

let customFrame = CGRect.init(origin: CGPoint.zero, size: CGSize.init(width: 0.0, height: self.containerView.frame.size.height))

webView = WKWebView(frame: customFrame, configuration: webConfiguration)
webView.uiDelegate = self
webView.navigationDelegate = self
self.containerView.addSubview(webView)
self.webView.translatesAutoresizingMaskIntoConstraints = false

self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .trailing, relatedBy: .equal, toItem: self.containerView, attribute: .trailing, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .leading, relatedBy: .equal, toItem: self.containerView, attribute: .leading, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .top, relatedBy: .equal, toItem: self.containerView, attribute: .top, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .bottom, relatedBy: .equal, toItem: self.containerView, attribute: .bottom, multiplier: 1, constant: 0))



progressView.sizeToFit()
progressView.progressTintColor = UIColor(red: 255/255, green: 204/255, blue: 0/255, alpha: 1.0)

webView.backgroundColor = UIColor.clear
webView.backgroundColor = UIColor(red: 0.0196, green: 0.4, blue: 0.2902, alpha: 1.0)
webView.isOpaque = false

webView.load(URLRequest(url: URL(string: "https://jwelsh19.wixsite.com/website-1")!))

self.webView.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)

//create a new button
let button = UIButton.init(type: .custom)
//set image for button
button.setImage(UIImage(named: "LogoMin"), for: UIControlState.normal)
//add function for button
button.addTarget(self, action: #selector(SportsViewController.acButtonPressed), for: UIControlEvents.touchUpInside)
//set frame
button.frame = CGRect(x: 0, y: 0, width: 32, height: 32)
button.widthAnchor.constraint(equalToConstant: 32.0).isActive = true
button.heightAnchor.constraint(equalToConstant: 32.0).isActive = true

let barButton = UIBarButtonItem(customView: button)
//assign button to navigationbar
self.navigationItem.leftBarButtonItem = barButton

let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: #selector(reloadWebView(_:)), for: .valueChanged)
refreshControl.tintColor = UIColor.white
webView.scrollView.addSubview(refreshControl)


@objc func reloadWebView(_ sender: UIRefreshControl)
webView.reload()
sender.endRefreshing()


override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?)
if keyPath == "estimatedProgress"
print(self.webView.estimatedProgress);
self.progressView.progress = Float(self.webView.estimatedProgress);


@IBAction func home(_ sender: UIButton)
let myURL = URL(string: "https://jwelsh19.wixsite.com/website-1")
let myRequest = URLRequest(url: myURL!)
webView.load(myRequest)


@IBAction func refresh(_ sender: UIButton)

webView.reload()



//This method will call when you press button.
@objc func acButtonPressed()

print("button is pressed")
self.performSegue(withIdentifier: "Account", sender: self)











share|improve this question
























  • possible duplicate of stackoverflow.com/questions/46289653/…

    – Alex Bailey
    Nov 14 '18 at 2:22











  • No answer to the question on that page

    – Nigel Denny
    Nov 14 '18 at 2:58











  • Do you have control of the HTML you are displaying?

    – Spads
    Nov 17 '18 at 13:31











  • I don't have control...

    – Nigel Denny
    Nov 19 '18 at 6:05















0















What I want:



I'm trying to figure out how to set the minimum and maximum zoom onWKWebView.
I've searched through a lot of people who asked similar questions but no solutions has worked in my code.
If there is no option to set the minimum and maximum zoom, I would like to know how to disable zoom on WKWebView entirely.



 import UIKit
import WebKit

class CalendarViewController: UIViewController, WKNavigationDelegate, WKUIDelegate

var webView: WKWebView!
@IBOutlet weak var containerView: UIView!
@IBOutlet weak var progressView: UIProgressView!

override func loadView()
super.loadView()


override func viewDidLoad()
super.viewDidLoad()


progressView.setProgress(0.1, animated: true)

let webConfiguration = WKWebViewConfiguration()
webConfiguration.applicationNameForUserAgent = "Version/8.0.2 Safari/600.2.5"

let customFrame = CGRect.init(origin: CGPoint.zero, size: CGSize.init(width: 0.0, height: self.containerView.frame.size.height))

webView = WKWebView(frame: customFrame, configuration: webConfiguration)
webView.uiDelegate = self
webView.navigationDelegate = self
self.containerView.addSubview(webView)
self.webView.translatesAutoresizingMaskIntoConstraints = false

self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .trailing, relatedBy: .equal, toItem: self.containerView, attribute: .trailing, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .leading, relatedBy: .equal, toItem: self.containerView, attribute: .leading, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .top, relatedBy: .equal, toItem: self.containerView, attribute: .top, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .bottom, relatedBy: .equal, toItem: self.containerView, attribute: .bottom, multiplier: 1, constant: 0))



progressView.sizeToFit()
progressView.progressTintColor = UIColor(red: 255/255, green: 204/255, blue: 0/255, alpha: 1.0)

webView.backgroundColor = UIColor.clear
webView.backgroundColor = UIColor(red: 0.0196, green: 0.4, blue: 0.2902, alpha: 1.0)
webView.isOpaque = false

webView.load(URLRequest(url: URL(string: "https://jwelsh19.wixsite.com/website-1")!))

self.webView.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)

//create a new button
let button = UIButton.init(type: .custom)
//set image for button
button.setImage(UIImage(named: "LogoMin"), for: UIControlState.normal)
//add function for button
button.addTarget(self, action: #selector(SportsViewController.acButtonPressed), for: UIControlEvents.touchUpInside)
//set frame
button.frame = CGRect(x: 0, y: 0, width: 32, height: 32)
button.widthAnchor.constraint(equalToConstant: 32.0).isActive = true
button.heightAnchor.constraint(equalToConstant: 32.0).isActive = true

let barButton = UIBarButtonItem(customView: button)
//assign button to navigationbar
self.navigationItem.leftBarButtonItem = barButton

let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: #selector(reloadWebView(_:)), for: .valueChanged)
refreshControl.tintColor = UIColor.white
webView.scrollView.addSubview(refreshControl)


@objc func reloadWebView(_ sender: UIRefreshControl)
webView.reload()
sender.endRefreshing()


override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?)
if keyPath == "estimatedProgress"
print(self.webView.estimatedProgress);
self.progressView.progress = Float(self.webView.estimatedProgress);


@IBAction func home(_ sender: UIButton)
let myURL = URL(string: "https://jwelsh19.wixsite.com/website-1")
let myRequest = URLRequest(url: myURL!)
webView.load(myRequest)


@IBAction func refresh(_ sender: UIButton)

webView.reload()



//This method will call when you press button.
@objc func acButtonPressed()

print("button is pressed")
self.performSegue(withIdentifier: "Account", sender: self)











share|improve this question
























  • possible duplicate of stackoverflow.com/questions/46289653/…

    – Alex Bailey
    Nov 14 '18 at 2:22











  • No answer to the question on that page

    – Nigel Denny
    Nov 14 '18 at 2:58











  • Do you have control of the HTML you are displaying?

    – Spads
    Nov 17 '18 at 13:31











  • I don't have control...

    – Nigel Denny
    Nov 19 '18 at 6:05













0












0








0


1






What I want:



I'm trying to figure out how to set the minimum and maximum zoom onWKWebView.
I've searched through a lot of people who asked similar questions but no solutions has worked in my code.
If there is no option to set the minimum and maximum zoom, I would like to know how to disable zoom on WKWebView entirely.



 import UIKit
import WebKit

class CalendarViewController: UIViewController, WKNavigationDelegate, WKUIDelegate

var webView: WKWebView!
@IBOutlet weak var containerView: UIView!
@IBOutlet weak var progressView: UIProgressView!

override func loadView()
super.loadView()


override func viewDidLoad()
super.viewDidLoad()


progressView.setProgress(0.1, animated: true)

let webConfiguration = WKWebViewConfiguration()
webConfiguration.applicationNameForUserAgent = "Version/8.0.2 Safari/600.2.5"

let customFrame = CGRect.init(origin: CGPoint.zero, size: CGSize.init(width: 0.0, height: self.containerView.frame.size.height))

webView = WKWebView(frame: customFrame, configuration: webConfiguration)
webView.uiDelegate = self
webView.navigationDelegate = self
self.containerView.addSubview(webView)
self.webView.translatesAutoresizingMaskIntoConstraints = false

self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .trailing, relatedBy: .equal, toItem: self.containerView, attribute: .trailing, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .leading, relatedBy: .equal, toItem: self.containerView, attribute: .leading, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .top, relatedBy: .equal, toItem: self.containerView, attribute: .top, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .bottom, relatedBy: .equal, toItem: self.containerView, attribute: .bottom, multiplier: 1, constant: 0))



progressView.sizeToFit()
progressView.progressTintColor = UIColor(red: 255/255, green: 204/255, blue: 0/255, alpha: 1.0)

webView.backgroundColor = UIColor.clear
webView.backgroundColor = UIColor(red: 0.0196, green: 0.4, blue: 0.2902, alpha: 1.0)
webView.isOpaque = false

webView.load(URLRequest(url: URL(string: "https://jwelsh19.wixsite.com/website-1")!))

self.webView.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)

//create a new button
let button = UIButton.init(type: .custom)
//set image for button
button.setImage(UIImage(named: "LogoMin"), for: UIControlState.normal)
//add function for button
button.addTarget(self, action: #selector(SportsViewController.acButtonPressed), for: UIControlEvents.touchUpInside)
//set frame
button.frame = CGRect(x: 0, y: 0, width: 32, height: 32)
button.widthAnchor.constraint(equalToConstant: 32.0).isActive = true
button.heightAnchor.constraint(equalToConstant: 32.0).isActive = true

let barButton = UIBarButtonItem(customView: button)
//assign button to navigationbar
self.navigationItem.leftBarButtonItem = barButton

let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: #selector(reloadWebView(_:)), for: .valueChanged)
refreshControl.tintColor = UIColor.white
webView.scrollView.addSubview(refreshControl)


@objc func reloadWebView(_ sender: UIRefreshControl)
webView.reload()
sender.endRefreshing()


override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?)
if keyPath == "estimatedProgress"
print(self.webView.estimatedProgress);
self.progressView.progress = Float(self.webView.estimatedProgress);


@IBAction func home(_ sender: UIButton)
let myURL = URL(string: "https://jwelsh19.wixsite.com/website-1")
let myRequest = URLRequest(url: myURL!)
webView.load(myRequest)


@IBAction func refresh(_ sender: UIButton)

webView.reload()



//This method will call when you press button.
@objc func acButtonPressed()

print("button is pressed")
self.performSegue(withIdentifier: "Account", sender: self)











share|improve this question
















What I want:



I'm trying to figure out how to set the minimum and maximum zoom onWKWebView.
I've searched through a lot of people who asked similar questions but no solutions has worked in my code.
If there is no option to set the minimum and maximum zoom, I would like to know how to disable zoom on WKWebView entirely.



 import UIKit
import WebKit

class CalendarViewController: UIViewController, WKNavigationDelegate, WKUIDelegate

var webView: WKWebView!
@IBOutlet weak var containerView: UIView!
@IBOutlet weak var progressView: UIProgressView!

override func loadView()
super.loadView()


override func viewDidLoad()
super.viewDidLoad()


progressView.setProgress(0.1, animated: true)

let webConfiguration = WKWebViewConfiguration()
webConfiguration.applicationNameForUserAgent = "Version/8.0.2 Safari/600.2.5"

let customFrame = CGRect.init(origin: CGPoint.zero, size: CGSize.init(width: 0.0, height: self.containerView.frame.size.height))

webView = WKWebView(frame: customFrame, configuration: webConfiguration)
webView.uiDelegate = self
webView.navigationDelegate = self
self.containerView.addSubview(webView)
self.webView.translatesAutoresizingMaskIntoConstraints = false

self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .trailing, relatedBy: .equal, toItem: self.containerView, attribute: .trailing, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .leading, relatedBy: .equal, toItem: self.containerView, attribute: .leading, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .top, relatedBy: .equal, toItem: self.containerView, attribute: .top, multiplier: 1, constant: 0))
self.view.addConstraint(NSLayoutConstraint(item: webView, attribute: .bottom, relatedBy: .equal, toItem: self.containerView, attribute: .bottom, multiplier: 1, constant: 0))



progressView.sizeToFit()
progressView.progressTintColor = UIColor(red: 255/255, green: 204/255, blue: 0/255, alpha: 1.0)

webView.backgroundColor = UIColor.clear
webView.backgroundColor = UIColor(red: 0.0196, green: 0.4, blue: 0.2902, alpha: 1.0)
webView.isOpaque = false

webView.load(URLRequest(url: URL(string: "https://jwelsh19.wixsite.com/website-1")!))

self.webView.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)

//create a new button
let button = UIButton.init(type: .custom)
//set image for button
button.setImage(UIImage(named: "LogoMin"), for: UIControlState.normal)
//add function for button
button.addTarget(self, action: #selector(SportsViewController.acButtonPressed), for: UIControlEvents.touchUpInside)
//set frame
button.frame = CGRect(x: 0, y: 0, width: 32, height: 32)
button.widthAnchor.constraint(equalToConstant: 32.0).isActive = true
button.heightAnchor.constraint(equalToConstant: 32.0).isActive = true

let barButton = UIBarButtonItem(customView: button)
//assign button to navigationbar
self.navigationItem.leftBarButtonItem = barButton

let refreshControl = UIRefreshControl()
refreshControl.addTarget(self, action: #selector(reloadWebView(_:)), for: .valueChanged)
refreshControl.tintColor = UIColor.white
webView.scrollView.addSubview(refreshControl)


@objc func reloadWebView(_ sender: UIRefreshControl)
webView.reload()
sender.endRefreshing()


override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?)
if keyPath == "estimatedProgress"
print(self.webView.estimatedProgress);
self.progressView.progress = Float(self.webView.estimatedProgress);


@IBAction func home(_ sender: UIButton)
let myURL = URL(string: "https://jwelsh19.wixsite.com/website-1")
let myRequest = URLRequest(url: myURL!)
webView.load(myRequest)


@IBAction func refresh(_ sender: UIButton)

webView.reload()



//This method will call when you press button.
@objc func acButtonPressed()

print("button is pressed")
self.performSegue(withIdentifier: "Account", sender: self)








ios swift zoom wkwebview pinchzoom






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 14 '18 at 3:39









Homam

192




192










asked Nov 14 '18 at 0:09









Nigel DennyNigel Denny

697




697












  • possible duplicate of stackoverflow.com/questions/46289653/…

    – Alex Bailey
    Nov 14 '18 at 2:22











  • No answer to the question on that page

    – Nigel Denny
    Nov 14 '18 at 2:58











  • Do you have control of the HTML you are displaying?

    – Spads
    Nov 17 '18 at 13:31











  • I don't have control...

    – Nigel Denny
    Nov 19 '18 at 6:05

















  • possible duplicate of stackoverflow.com/questions/46289653/…

    – Alex Bailey
    Nov 14 '18 at 2:22











  • No answer to the question on that page

    – Nigel Denny
    Nov 14 '18 at 2:58











  • Do you have control of the HTML you are displaying?

    – Spads
    Nov 17 '18 at 13:31











  • I don't have control...

    – Nigel Denny
    Nov 19 '18 at 6:05
















possible duplicate of stackoverflow.com/questions/46289653/…

– Alex Bailey
Nov 14 '18 at 2:22





possible duplicate of stackoverflow.com/questions/46289653/…

– Alex Bailey
Nov 14 '18 at 2:22













No answer to the question on that page

– Nigel Denny
Nov 14 '18 at 2:58





No answer to the question on that page

– Nigel Denny
Nov 14 '18 at 2:58













Do you have control of the HTML you are displaying?

– Spads
Nov 17 '18 at 13:31





Do you have control of the HTML you are displaying?

– Spads
Nov 17 '18 at 13:31













I don't have control...

– Nigel Denny
Nov 19 '18 at 6:05





I don't have control...

– Nigel Denny
Nov 19 '18 at 6:05












0






active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53291300%2fset-minimum-and-maximum-zoom-on-wkwebview-or-disabling-it-entirely%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53291300%2fset-minimum-and-maximum-zoom-on-wkwebview-or-disabling-it-entirely%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







這個網誌中的熱門文章

How to read a connectionString WITH PROVIDER in .NET Core?

Node.js Script on GitHub Pages or Amazon S3

Museum of Modern and Contemporary Art of Trento and Rovereto