swift控件工厂类的实现代码

控件工厂类,简而言之就是,减少代码的复用率,只在哪里用,然后在哪里调:

代码如下:

import UIKit

class ViewFactory: UIView,UITextFieldDelegate {

  //默认控件的尺寸
  class func getDefaultFrame( ) -> CGRect
  {
    let defaultFrame = CGRect(x:0,y:0,width:100,height:30)
    return defaultFrame
  }

  //类方法
  class func createControl(type:String,title:[String],action:Selector,sender:AnyObject) -> UIView
  {
    switch type {
    case "label":
      return ViewFactory.creatLabel(title: title[0])
      case "button":
      return ViewFactory.createButton(title: title[0], action: action, sender: sender as! UIViewController)
      case "text":
      return ViewFactory.creatTextField(value: title[0], action: action, sender: sender as! UIViewController as UIViewController as! UITextFieldDelegate)
      case "segment":
      return ViewFactory.creatSegment(items: [title[0]], action: action, sender: sender as! UIViewController)
    default:
      return ViewFactory.creatLabel(title: title[0])
    }
  }

  //创建按钮控件
  class func createButton(title:String, action:Selector, sender:UIViewController)
    -> UIButton {
      let button = UIButton(frame:ViewFactory.getDefaultFrame())
      button.backgroundColor = UIColor.orange
      button.setTitle(title, for:.normal)
      button.titleLabel!.textColor = UIColor.white
      button.titleLabel!.font = UIFont.systemFont(ofSize: 14)
      button.addTarget(sender, action:action, for:.touchUpInside)
      return button
  }

  //创建文本输入框控件
  class func creatTextField(value:String,action:Selector,sender:UITextFieldDelegate) -> UITextField
  {
    let textField = UITextField(frame:ViewFactory.getDefaultFrame())
    textField.backgroundColor = UIColor.clear
    textField.textColor = UIColor.black
    textField.text = value
    textField.borderStyle = .roundedRect
    textField.adjustsFontSizeToFitWidth = true
    textField.delegate = sender
    return textField
  }

  //创建分段单选组件
  class func creatSegment(items:[String],action:Selector,sender:UIViewController) -> UISegmentedControl
  {
    let segment = UISegmentedControl(items:items)
    segment.frame = ViewFactory.getDefaultFrame()
    segment.isMomentary = false
    segment.addTarget(self, action: action, for: .valueChanged)
    return segment
  }

  //创建文本标签控件
  class func creatLabel(title:String) -> UILabel
  {
    let label = UILabel()
    label.textColor = UIColor.black
    label.backgroundColor = UIColor.white
    label.text = title
    label.frame = ViewFactory.getDefaultFrame()
    label.font = UIFont(name:"微软雅黑",size:16)
    return label

  }
}

调用:

 func initVIewFactory()
  {
    //创建文本标签
    let labelNum = ViewFactory.creatLabel(title: "阈值")
    labelNum.frame = CGRect(x:20,y:100,width:60,height:30)
    self.view.addSubview(labelNum)

    let labelDm = ViewFactory.creatLabel(title: "维度")
    labelDm.frame = CGRect(x:20,y:200,width:60,height:30)
    self.view.addSubview(labelDm)

    //创建文本输入框
    textNum = ViewFactory.creatTextField(value: "", action:#selector(factoryAction), sender: self as UITextFieldDelegate)
    textNum.frame = CGRect(x:80,y:100,width:200,height:30)
    textNum.returnKeyType = .done
    self.view.addSubview(textNum)

    let textNumSecond = ViewFactory.creatTextField(value: "", action: #selector(factoryActionSecond), sender: self as UITextFieldDelegate)
    textNumSecond.frame = CGRect(x:80,y:200,width:200,height:30)
    textNum.returnKeyType = .done
    self.view.addSubview(textNumSecond)

    //创建分段单选控件
    segmentC = ViewFactory.creatSegment(items: ["3*3","4*4","5*5"], action: #selector(segmentAction), sender: self)
    segmentC.frame = CGRect(x:80,y:200,width:200,height:30)
    self.view.addSubview(segmentC)
    segmentC.selectedSegmentIndex = 0

    //创建按钮控件
    factorybtn = ViewFactory.createButton(title: "确定", action: #selector(factoryClick), sender: self)
    factorybtn.frame.origin = CGPoint(x:80,y:300)
    self.view.addSubview(factorybtn)

  }

  func factoryAction()
  {

  }

  func factoryActionSecond()
  {

  }

  func segmentAction()
  {

  }

  func factoryClick()
  {
    print("我点击了")
  }

效果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Swift在控件中添加点击手势的方法

    今天有同行问我,如何在tableview的headerview中添加点击方法,今天就来简简单单说明一下,在swift中添加点击手势的方法是: 复制代码 代码如下: imagepath.addGestureRecognizer(UITapGestureRecognizer(target: self, action: "imagePathClick:")) 怎么样,看上去是不是比oc简单多了呢,简单解释一下,imagePath是我定义的一个UIImageView,可能有人添加了这个手势之后

  • swift控件工厂类的实现代码

    控件工厂类,简而言之就是,减少代码的复用率,只在哪里用,然后在哪里调: 代码如下: import UIKit class ViewFactory: UIView,UITextFieldDelegate { //默认控件的尺寸 class func getDefaultFrame( ) -> CGRect { let defaultFrame = CGRect(x:0,y:0,width:100,height:30) return defaultFrame } //类方法 class func c

  • 递归输出ASP.NET页面所有控件的类型和ID的代码

    写一个方法: 复制代码 代码如下: private void DisplayAllControl(Control control, int step) { foreach (Control ctl in control.Controls) { string s = new string('-', step * 4) + ctl.GetType().Name + "〈" + ctl.ID + "〉"; Response.Write(s + "<br/&

  • PyQt5事件处理之定时在控件上显示信息的代码

    有时候为了体现延时效果,或者是多事件处理,需要在窗口的文本编辑框或者表格等控件中,延迟几秒或每隔几秒显示输出一段数据,又或者可以说是每隔几秒执行下一行代码!要实现这种效果,关键的两个方法就是time.sleep()与processEvents(),具体看如下代码: from PyQt5 import QtCore, QtGui, QtWidgets import sys from PyQt5.QtWidgets import * import time class Ui_MainWindow(o

  • 动态向页面添加控件和使用正则表达式的代码

    复制代码 代码如下: namespace WebCode { public partial class _default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { String str = "这是一个测试文件<{config name=\"pagetitle1\"}>,一个标签的解析<{config name=\"pagetitle2\

  • 验证用户必选CheckBox控件与自定义验证javascript代码

    CheckBox控件,由于它的值是选择与非选择.因此在提交数据时,想让用户必须选择CheckBox,普通情况之下,不好做验证. 但我们可以使用asp:CustomValidator来验证,不过还得写自定义验证Javascript代码,可参考如下: 复制代码 代码如下: function ValidateCheckBox(sender, args) { var checkbox = document.getElementById("<%=CheckBox1.ClientID %>&qu

  • js 判断控件获得焦点的示例代码

    JS判断一个对象已获得焦点document.activeElement.tagName //tagName 标签名 实例:判断body获得光标时关闭输入法. 复制代码 代码如下: var act = document.activeElement.tagName.toLowerCase();   if(act.indexOf("body") != -1 || act.indexOf("html") != -1)   {    document.body.style.i

  • 基于jquery的让页面控件不可用的实现代码

    应用背景 当用户需要某项功能时要填写一些表单信息,在填写完成并提交后,该部分信息是不允许再次修改的.表单包含TextBox.DropDownList.CheckBox等控件. 需求实现 第一种方案,绑定用户填写的数据时,设置控件的Enable属性为False.如果页面的表单数较少时可采用这样的方法,但是如果在表单较多的情况下则并不是更好的方法. 第二种方案,使用Foreach访问页面控件,判断类型如果是TextBox.DropDownList.CheckBox等,则设置Enable=False.

  • Android HorizontalScrollView内子控件横向拖拽实例代码

    前言 网上ListView上下拖动的例子有,效果也很好,但是项目要横着拖的,只要硬着头皮自己写(主要是没找到合适的),参考文章1修改而来,分享一下. 正文 截图 实现代码: public class HoDragActivity extends Activity { private LinearLayout main; private GestureDetector mGestureDetector; @Override public void onCreate(Bundle savedInst

  • Android给布局、控件加阴影效果的示例代码

    增加阴影效果,让控件或者布局看起来有立体的效果,总的来说有两种解决方案. 1,直接使用属性: android:elevation="4dp"这样一句代码,就实现了效果,elevation表示海拔,就是布局的z轴的高度,调整高度,可以选择阴影的轻重. <TextView android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight=&

  • JQuery select控件的相关操作实现代码

    获取select 先看看下面代码: 复制代码 代码如下: $("#select_id").change(function(){//code...}); //为Select添加事件,当选择其中一项时触发 var checkText=$("#select_id").find("option:selected").text(); //获取Select选择的Text var checkValue=$("#select_id").val

随机推荐