swift控件工厂类的实现代码

 更新时间:2017年09月29日 11:07:29   作者:稻草人11223  
这篇文章主要为大家详细介绍了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("我点击了")
  }


效果如下:

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

您可能感兴趣的文章:

相关文章

  • Swift 图表使用Foudation库中测量类型详解

    Swift 图表使用Foudation库中测量类型详解

    这篇文章主要为大家介绍了Swift 图表使用Foudation库中测量类型详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 详解如何在SwiftUI中创建悬浮操作按钮

    详解如何在SwiftUI中创建悬浮操作按钮

    悬浮操作按钮(Floating Action Button, FAB)是一种在 Android 和 Material Design 中使用的 UI 元素,它用于触发特定屏幕的主要操作,下面我们就来详细介绍一下如何在SwiftUI中创建悬浮操作按钮,需要的朋友可以参考下
    2023-10-10
  • Swift教程之方法详解

    Swift教程之方法详解

    这篇文章主要介绍了Swift教程之方法详解,方法是关联到一个特定类型的函数,类、结构、枚举所有可以定义实例方法,封装特定任务和功能处理给定类型的一个实例,需要的朋友可以参考下
    2015-01-01
  • 浅谈swift 4.0中private所发生的变化

    浅谈swift 4.0中private所发生的变化

    Swift 4是苹果计划于2017年秋季推出的最新版本,其主要重点是提供与Swift 3代码的源兼容性,并努力实现ABI稳定性。下面这篇文章主要给大家介绍了关于swift 4.0中private所发生的一些变化,需要的朋友可以参考下。
    2017-12-12
  • swift中可选值?和!使用的方法示例

    swift中可选值?和!使用的方法示例

    这篇文章主要给大家介绍了关于swift中可选值?和!使用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-11-11
  • 深入浅出的聊聊Swift高阶函数

    深入浅出的聊聊Swift高阶函数

    函数式编程就是高阶函数编程的应用,所以要熟练掌握基础的高阶函数是必须的filter、map、reduce、flatmap就是必备的高阶函数,这篇文章主要给大家介绍了关于Swift高阶函数的相关资料,需要的朋友可以参考下
    2021-09-09
  • 深入理解Swift中的变量与常量

    深入理解Swift中的变量与常量

    本文主要是介绍Swift中最常用的常量和变量,将从“变量常量的定义”、"如何声明变量常量"、“变量和常量的命名”,"变量常量的本质区别"四个方面入手,重点介绍变量和常量的使用以及区别,希望大家在阅读完本文后都可以熟练使用它们。有需要的朋友们下面来一起学习吧。
    2017-01-01
  • Swift中添加双击手势识别器

    Swift中添加双击手势识别器

    在这次IOS应用开发教程中,我们打算实现手势识别。正如你所知道的,IOS支持大量的手势操作,它们能提供了很好的应用控制和出色用户体验。
    2019-08-08
  • Swift Extension扩展得使用详细介绍

    Swift Extension扩展得使用详细介绍

    在swift中,extension与Objective-C的category有点类似,但是extension比起category来说更加强大和灵活,它不仅可以扩展某种类型或结构体的方法,同时它还可以与protocol等结合使用,编写出更加灵活和强大的代码
    2022-09-09
  • Swift心得笔记之控制流

    Swift心得笔记之控制流

    控制流(Control Flow)我不想这么译的。。。我更想叫控制语句,但是想想,这么叫也没错,意指流程控制。大部分用法跟C类似。
    2015-04-04

最新评论