oc 项目调用swift_swift项目oc调用swift - CSDN
  • iOS OC项目调用Swift

    万次阅读 2017-03-17 13:51:27
    网上有很多关于OC项目中使用Swift类的方法,但是亲自试了之后,发现不够详细,多次尝试后,终于找出详细的方法。 现把方法和遇到的问题,记录下来,方便其他同仁借鉴.

    网上有很多关于OC项目中使用Swift类的方法,但是亲自试了之后,发现不够详细,多次尝试后,终于找出详细的方法。
    现把方法和遇到的问题,记录下来,方便其他同仁借鉴:

    一、新建一个OC工程,工程名称自定,在这里我定义为OCAndSwiftDemo,如图:

    新建项目架构图

    二、在新建Swift类之前,进行相关设置,如图:

    相关设置

    三、在项目中,新建一个TestDemo的swift类,点击Create后,提示如图:

    创建OC调用Swift类的桥接文件

    选择Create Bridging Header,一定要选择这个,如果不选择,就引入不了Swift类,然后生成”项目名称-Bridging-Header.h”桥接文件

    然后编辑Swift类,如果Swift类想要被OC发现,必须继承自NSObject,如图:

    TestDemo类

    四、调用Swift类,我们想要调用Swift类的方法里面引入头文件:”项目名称-Swift.h”,如图:

    调用Swift类

    注释:如果调用不了Swift类,可以先Shift+Command+R一下。

    展开全文
  • 虽然网上关于swift和oc混合编程的教程比较多,但是大多是基于 swift项目的,所以对咱们 OCer的参考价值有一定折扣. 现在swift虽然仍然存在很多缺陷,但是鉴于苹果的强势,是时候在项目中把简单的功能交给swift了,给...
     对于已经工作的开发者,并不适合也没有条件从一个全新的swift项目开始,进行开发. 虽然网上关于swift和oc混合编程的教程比较多,但是大多是基于 swift项目的,所以对咱们 OCer的参考价值有一定折扣.
    • 现在swift虽然仍然存在很多缺陷,但是鉴于苹果的强势,是时候在项目中把简单的功能交给swift了,给自己,给项目,给swift一个缓冲区,都是极好的.

      说了这么多,开始上代码.

      现在的背景是: 已经有一个oc项目了,我想要加入 swfit,并且实现 oc调用 swift ,swift调用oc .

      1.新建一个swift文件

      2.接下来会询问你是否建立桥接文件,点击是 ,那么我后面的就是多余的了,所以选择取消,我们手动建立桥接文件

      3.手动建立桥接文件:新建头文件

      关于命名: 有经验的人都知道,这个头文件是项目公用的,同时如果自动创建,文件名也是 :

      项目名-Bridging-Header.h

      但是因为我现在的项目名是中文,所以我自己命名了一下.

       

      4. 配置头文件

      在build setting里面搜索 swift ,根据实际情况进行配置:

      注意:是相对于工程文件所在的相对路径.从 Finder里面看,不要让项目中得group扰乱你的判断

      5.在头文件中引入需要的 oc头文件,这里我就用 UIKit了

       

      6.编写代码

       

      可以看到,我们可以使用UIKit的类了

      注意:关于自定义类,希望有个好的命名规范,那么在混合编程中,你将受益无穷

      7.oc调用swift

      现在因为测试我想把窗口的根控制器设置为我的swift的那个.

      因为swift没有头文件,所以不好办了...

      其实,系统默认给我们生成了头文件(需要我们的swift类是NSObject的直接或者间接子类),我们只要引入

      项目名-Swift.h

      没办法了,我的项目名是中文...

      引入:

      8.使用 swift的类

      9.运行

      一切正常 (好丑,不要吐槽)

       


    展开全文
  • [Swift]1.在OC项目里的OC代码调用Swift方法,Swift代码里调用OC代码。2.在Swift项目里的Swift代码里调用OC代码,OC代码调用Swift方法。
  • OC项目中使用Swift

    万次阅读 2016-02-27 09:23:30
    OC项目中使用Swift 本文版权归作者所有,如需转载请联系孟祥月 CSDN博客:http://blog.csdn.net/mengxiangyue 独立博客:http://mengxiangyue.com 最近公司的项目开始计划使用Swift,由于原先的工程都是使用...

    OC项目中使用Swift

    本文版权归作者所有,如需转载请联系孟祥月
    CSDN博客:http://blog.csdn.net/mengxiangyue
    独立博客:http://mengxiangyue.com

    最近公司的项目开始计划使用Swift,由于原先的工程都是使用OC编写的,不可能一下全部转换成Swift,所以采用OC与Swift混编的方式是最好的选择。这篇文章只是一个简单的介绍,并没有太高深的知识。

    我新建了一个演示的OC工程,当然你可以使用你已经存在的OC的工程。如果我们想要在OC工程中使用Swift的代码,Swift的代码默认是使用module管理的,同样这里我们也需要把我们的Swift代码作为一个module暴露给我们的OC工程,修改下面的配置:

    上面的修改了一个配置项,有一个Product Module Name在后面会使用。

    在工程里面点击File/New/File…,选择iOS/Source/Cocoa Touch Class,按照如下填写创建一个新的文件:

    上图中的Subclass of一定要设置为NSObject或其子类,否则OC工程将不会找到该类。

    点击确认后会选择保存路径,点击Create,出现如下界面:

    这个界面是询问是否创建桥接的头文件,这个文件在Swift调用OC代码的时候比较管用,但是在OC中调用Swift的时候我发现没有什么卵用。

    选择Don’t Create按钮。

    在Test.swift中添加如下的代码(解释都在注释里面了):

    import UIKit
    
    /*
        如果Swift类想要被OC发现,必须继承自NSObject并且使用public标记,并且该类中想要被OC访问的方法也必须使用public标记,具体知识可以去看Swift的访问控制
        原因:Swift的代码对于OC来说是作为一个module存在的
    
        当然全局的Swift函数,我还没发现怎么在OC中访问,如果哪位清楚还请告诉一下,谢谢!
    */
    
    
    public class Test: NSObject {
        public func log() {
            print("这是Swift的方法")
        }
    }
    
    public func globalLog() {
        print("这是Swift全局的log方法")
    }

    我们在我们想要调用Swift类的方法里面引入头文件:”Product Module Name-Swift.h”,其中Product Module Name替换成在上面配置项中显示的内容,例如:

    #import "ViewController.h"
    // 引入Swift头文件
    #import "OCAndSwift-Swift.h"
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
    
        // 使用Swift的类
        Test *test = [[Test alloc] init];
        [test log];
    }
    
    @end

    这样我们就能够在OC中使用Swift的代码了,最后还要说明一点:”Product Module Name-Swift.h”(例子中的是OCAndSwift-Swift.h),是由编译器自动生成的,如果import后没有提示,编译一下。并且只有在工程中包含至少一个Swift文件的时候,才会自动生成这个文件,所以如果工程中如果没有Swift文件的时候,就算在配置中设置对了,import该文件也会报错。

    展开全文
  • 最新一些学妹问起,所以抽点时间来写的,适合入门级别的swiftOC 混编 的程序猿。 本文章将从两个方向分别介绍 OCswift 混编 1. 第一个方向从 swift工程 中引入 oc类   1. 1 如何在swift的类中使用oc类 ...

    最新一些学妹问起,所以抽点时间来写的,适合入门级别的swift 与 OC 混编 的程序猿。  

    本文章将从两个方向分别介绍 OC 与 swift 混编  


    1. 第一个方向从 swift工程 中引入 oc类 

        1. 1 如何在swift的类中使用oc类
        1.2  如何在swift中实现oc的代理方法
        1.3   如何在swift中实现oc的Block回调

    2. 第二个方向从OC工程中引入swift类

        2.1  如何在OC类中使用swift类
        2.2   如何在OC中实现swift的代理方法
        2.3   如何在OC中实现swift中类似Block回调


    下面是具体的实现过程:

     1.1  如何在swift的类中使用oc类? 

    1.  swift工程中引入OC类。 具体实现过程。

        1.1 新建一个swift工程类。 取名 swiftOrOC

        1.2  实现的功能为 :  从swift. viewController.swift 中 push到 OC语言 secondViewController 控制器

    1.2.1  新建SecondViewController 类 。

            

         1.2.2 建立桥接文件。 (很重要)


        一定要记得点击这个按钮。 

           1.2.3  接下来工程目录如下:

           

         1.2.4 接下来就可以实现具体的跳转功能了。 

          ViewController.swift中具体实现

         

    import UIKit
    
    class ViewController: UIViewController {
    
        @IBOutlet weak var hintLabel: UILabel!  //稍后用来显示回调
        
        // push 到 oc controller
        @IBAction func pushAction(_ sender: AnyObject) {
            let secondVC = SecondViewController.init()
            self.navigationController?.pushViewController(secondVC, animated: true)
        }
        
        override func viewDidLoad() {
            super.viewDidLoad()
            // Do any additional setup after loading the view, typically from a nib.
        }
    
        override func didReceiveMemoryWarning() {
            super.didReceiveMemoryWarning()
            // Dispose of any resources that can be recreated.
        }
    
    
    }
    


    1.2 如何在swift中实现oc的代理方法

           1.2.1 首先在 SecondViewController.h 中声明一个协议。具体代码

            

    #import <UIKit/UIKit.h>
    
    @protocol SecondDelegate <NSObject>
    
    -(void)refreshHintLabel:(NSString *)hintString;
    
    @end
    
    @interface SecondViewController : UIViewController
    
    @property (nonatomic,weak)id<SecondDelegate> secondDelegate;
    @end
    
         1.2.2 然后在SecondViewController.m中,通过一个UITextField,让用户输入内容,当用户点击返回的时候把输入框中的内容返回给对应的代理。具体代码如下

        

    #import "SecondViewController.h"
    #import "UIViewController+BackButtonHandler.h"
    
    @interface SecondViewController ()
    {
        UITextField *textField;
    }
    @end
    
    @implementation SecondViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        self.title = @"oc";
        
        self.view.backgroundColor  = [UIColor whiteColor];
        
        textField = [[UITextField alloc]initWithFrame:CGRectMake(100, 100, 200, 200)];
        textField.placeholder = @"请输入用户名";
        [self.view addSubview:textField];
        [textField.layer setBorderColor:[UIColor blackColor].CGColor];
        [textField.layer setBorderWidth:1.0];
    
        
    }
    
    -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
        [self.view endEditing:YES];
    }
    #pragma mark 返回上一页回调 ,将用户输入的用户名传回给 ViewController.swift
    -(BOOL)navigationShouldPopOnBackButton{
        if ([_secondDelegate respondsToSelector:@selector(refreshHintLabel:)]) {
            [_secondDelegate refreshHintLabel: textField.text];
        }
        
        return YES;
    }
    
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    /*
    #pragma mark - Navigation
    
    // In a storyboard-based application, you will often want to do a little preparation before navigation
    - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
        // Get the new view controller using [segue destinationViewController].
        // Pass the selected object to the new view controller.
    }
    */
    
    @end
    
      1.2.3 接下来就非常简单了,让ViewController.swift只需要成为SecondViewController的代理,然后遵循她的协议,就可以了。 具体代码如下。

           1.2.3.1 遵循协议

      

         1.2.3.2 成为代理,并实现协议方法,更改controller.swift中hintLabel的text。

        // push 到 oc controller
        @IBAction func pushAction(_ sender: AnyObject) {
            let secondVC = SecondViewController.init()
            secondVC.secondDelegate = self;
            self.navigationController?.pushViewController(secondVC, animated: true)
        }
        
        // SecondViewControll的代理方法
        func refreshHintLabel(_ hintString: String!) {
            hintLabel.text = "secondView textView.text = " + hintString;
        }
        

     1.3   如何在swift中实现oc的Block回调

    1.3.1 具体过程与1.2小节一样。 直接上代码。

            1.3.2 声明block;

             

    typedef void(^RefreshHintLabelBlock)(NSString *hintString);
    
    @interface SecondViewController : UIViewController
    @property (nonatomic, copy) RefreshHintLabelBlock hintBlock;
    @end

            1.3.3 block的回调。 SecondViewController.m中

    #pragma mark 返回上一页回调 ,将用户输入的用户名传回给 ViewController.swift
    -(BOOL)navigationShouldPopOnBackButton{    
        if (_hintBlock) {
            _hintBlock(textField.text);
        }
        return YES;
    }
    

            1.3.4 在swift类中调用 oc的block.

        // push 到 oc controller
        @IBAction func pushAction(_ sender: AnyObject) {
            let secondVC = SecondViewController.init()
    //        secondVC.secondDelegate = self;
            secondVC.hintBlock = {(t:String?)in
                self.hintLabel.text = "secondView textView.text = " + t!
            }
            self.navigationController?.pushViewController(secondVC, animated: true)
        }


       工程已上传到git上,git地址: https://github.com/zhonggaorong/SwiftOrOc/tree/master

    2.  OC工程中引入swift类。 具体实现过程。

        耽误了不少时间, 今天才开始写oc工程中引入swift类。

        demo地址: 

      

         2.1  如何在OC类中使用swift类


           2.1.1   新建一个基于OC语言的工程 ,取名 OcOrSwiftTwo
           2.1. 2  实现的功能为 : 从oc类 viewcontroller中, push 至 swift语言 SecondViewController  ,然后SecondViewController可以通过代理或者swift闭包把值传回viewcontroller. 
           2.1.3   当前文件目录看下图:  (第四个箭头: 桥接文件)
            
      
        2.2   如何在OC中实现swift的代理与闭包Block方法
                
        2.2.1 如何在oc中引入swift类。#import "工程名-swift.h"
    #import "OcOrSwiftTwo-swift.h"
       2.2.2 在secondViewController.swift 中实现代理与闭包,代码如下:
        注意: @objc(代理名)  才能在外部可见这个代理
     
    import UIKit
    import Foundation
    
    // 必须加上@objc 代理才能在oc类中可见。
    @objc(EditTextFieldDelegate)
    protocol EditTextFieldDelegate:NSObjectProtocol {
        func editTextField(_ str: String) -> Void
    }
    
    @objc(SecondViewController)
    class SecondViewController: UIViewController {
    
        var editorDelegate:EditTextFieldDelegate?
        var textField:UITextField?
        var addButton:UIButton?
        var pushButton:UIButton?
        
        typealias editorBlock = (_ t:String) -> Void
        var myEidtorBlock:editorBlock?
        
        override func viewDidLoad() {
            super.viewDidLoad()
            self.view.backgroundColor = UIColor.white
            textField = UITextField.init(frame: CGRect.init(x: 50, y: 60, width: 200, height: 50))
            textField?.placeholder = "输入返回首页的内容"
            self.view.addSubview(textField!)
            
            addButton = UIButton.init(type: .custom)
            addButton?.setTitleColor(UIColor.black, for: .normal)
            addButton?.setTitle("pop", for: .normal)
            addButton?.frame = CGRect.init(x: 50, y: 150, width: 200, height: 50)
            addButton?.layer.borderColor = UIColor.black.cgColor
            addButton?.layer.borderWidth = 1.0
            addButton?.addTarget(self, action: #selector(popAction), for: .touchUpInside)
            self.view.addSubview(addButton!)
            
            
            
            pushButton = UIButton.init(type: .custom)
            pushButton?.setTitleColor(UIColor.black, for: .normal)
            pushButton?.setTitle("push", for: .normal)
            pushButton?.frame = CGRect.init(x: 50, y: 250, width: 200, height: 50)
            pushButton?.layer.borderColor = UIColor.black.cgColor
            pushButton?.layer.borderWidth = 1.0
            pushButton?.addTarget(self, action: #selector(pushAction), for: .touchUpInside)
            self.view.addSubview(pushButton!)
            
        }
        
        func popAction() -> Void {
            
            if editorDelegate != nil {
                editorDelegate?.editTextField((textField?.text)!)
            }
            
            if ((self.myEidtorBlock) != nil){
                self.myEidtorBlock!((textField?.text!)!)
            }
            
            self.navigationController?.popViewController(animated: true)
        }
        
        
        func pushAction() -> Void {
            let three = ThreeViewController.init()
            self.navigationController?.pushViewController(three, animated: true)
            
        }     
        2.2.3   在oc类中viewcontroller.m 文件中实现SecondviewController.swift的相关代理与闭包(block). 代码如下:
       
    #import "ViewController.h"
    #import "OcOrSwiftTwo-swift.h"
    
    @interface ViewController ()<EditTextFieldDelegate>
    @property (nonatomic, strong) UITextField *showTextField;
    @property (nonatomic, strong) UIButton *pushButton;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        _showTextField = [[UITextField alloc]initWithFrame:CGRectMake(50, 100 , 200, 50)];
        _showTextField.placeholder = @"swift传回的文本内容";
        _showTextField.adjustsFontSizeToFitWidth = YES;
        _showTextField.enabled = NO;
        [self.view addSubview:_showTextField];
        
        _pushButton = [UIButton buttonWithType:UIButtonTypeCustom];
        [_pushButton.layer setBorderColor:[UIColor blackColor].CGColor];
        [_pushButton.layer setBorderWidth:1.0];
        [_pushButton setFrame:CGRectMake(50, 200, 200, 50)];
        [_pushButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
        [_pushButton setTitle:@"push" forState:UIControlStateNormal];
        [_pushButton addTarget:self action:@selector(pushAction) forControlEvents:UIControlEventTouchUpInside];
        
        [self.view addSubview:_pushButton];
    }
    
    
    
    
    -(void)pushAction{
        SecondViewController *second = [[SecondViewController alloc]init];
        // second.editorDelegate = self;
        
        /*
          swift中的闭包回滴
         */
        second.myEidtorBlock = ^(NSString *str) {
            _showTextField.text = [NSString stringWithFormat:@"second传回信息: %@",str];
        };
        [self.navigationController pushViewController:second animated:YES];
    }
    
    #pragma mark swift中的代理
    -(void)editTextField:(NSString *)str{
        _showTextField.text = [NSString stringWithFormat:@"second传回信息: %@",str];
    }
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    


    展开全文
  • OC调用Swift代码方法

    千次阅读 2018-06-03 09:27:48
    最近在项目中使用到了Swift语言写的第三方的框架,所以在这里将OC中使用Swift的方法说明一下。1.首先要在Build Setting中进行相关配置2.在Podfile文件中要加上use_frameworks!为什么要加use_frameworks!呢?首先需要...
  • OC工程调用Swift方法

    万次阅读 2017-01-11 11:45:08
    1.建一个OC工程命名为SwiftOC 2.新建一个swfit文件命名为Test.swift,会弹出提示,选择Create Bridging Header建立桥接文件,系统会建立“工程名-Bridging-Header.h” 3.配置工程 设置Defines Module 为Yes ...
  • @OC调用Swift 方法 OC调用传多值参数Swift方法的处理 截止目前, Swift 已经达到4.2版本。有很多优秀的Swift库。有时需要OC和Swift混编。学习研究了一下FaceAware 人脸感知开源库。 Swift方法传多值参数及OC调用 ...
  • 之前在开发是遇到了在OC文件中调用Swift对象的变量调用不到的问题,这里总结一下: 1.首先我们一个Swift项目TestProject。 2.建立一个Swift的文件继承自NSObject名字为SwiftFile.swift,并声明一个字符串变量...
  • oc调用swift中的struct

    千次阅读 2016-09-05 10:26:53
    oc调用swift中的struct  在oc中是不能调用struct里面的内容的,你想在类似class前面加个@objc的方法加在struct前面,你是发现是不行的,那但是我们又想在oc中调用struct的属性,那怎么办呢?我们只能够再建一...
  • swift中使用OC的方法;在OC调用swift方法
  • OC调用Swift方法

    千次阅读 2018-05-02 15:36:48
    第一步:创建桥接文件第二步:配置桥接文件第三步:创建pch文件并配置其路径 第四步:在pch文件中导入如下头文件,注意:...,这里的xxx就是第二步中的Module name, 注意不要写错了 第五步:OC中直接调用Swift...
  • swift项目中,OC和swift文件相互调用

    千次阅读 2017-08-10 13:40:38
    有时候 ,我们会涉及到双向混合编程,特别是OC和swift的互相引用。   swift调用oc的方法: ...1、桥接文件,一般是swift工程,在创建一个oc文件时,系统自动添加(不用改名,直接默认即可) ...oc调用swift
  • oc调用swift

    千次阅读 2015-11-14 18:05:06
    如果你想在Objective-C工程中,嵌入Swift文件,实现OC调用Swift,那么这篇文章就能帮助你,由于本人最近在开发Swift项目,所以实现过OC调用Swift,在这过程中遇到过一些瓶颈,特此,将此文奉上,供大家参考。...
  • iOS oc 调用 swift

    2019-07-03 07:14:24
    如股票oc调用swift里面的代码 需要包含固定这个头文件 项目名称 LiqunSwiftDemo-Swift.h #ProjectName#-Swift.h 固定的写法 swift 目的 是取代oc 但是 不会完全取代 只是前端的替换 LiqunSwiftDemo-Swift 点...
  • OC 调用 Swift 方法

    千次阅读 2018-09-06 11:47:34
    1.新建Swift文件之前做以下设置 2.创建Swift文件后,会提示创建桥接文件,点击创建 3.Swift 类 import Foundation class RealmManager: NSObject { override init() { super.init() } @objc func ...
  • 本文章将从两个方向分别... 1 如何在swift的类中使用oc类 1.2 如何在swift中实现oc的代理方法 1.3 如何在swift中实现oc的Block回调 2 二个方向从OC工程中引入swift类    2.1 如何在OC类中使用swift类 2.2 如何...
  • OC 引用并调用Swift文件

    千次阅读 2019-07-24 17:09:03
    1、我们先创建一个OC项目MyFirstOCUseSwiftDemo 2、我们点击Target看到右边选择Build Settings,把Defines Module改为YES, 3、我们回到工程目录下,New File一个Swift File,起名为MyFristSwift,此时会...
  • iOS ocswift相互调用

    2020-09-04 16:59:32
    oc调用swift 在需要调用swift的oc文件中引入“ProjectName-Swift.h” #import "ProjectName-Swift.h" 注意: 调用的swift类必须继承于NSObject, 不是继承自NSObject的类或是swift的结构体oc是无法调用的 swift...
  • swiftOC混编(方法调用

    万次阅读 2016-02-12 10:35:31
    OC调用SwiftOC调用Swift方法比较简单。但是需要注意以下几点: 1.需要在当前OC类里导入xxx-Swift.h头文件,其中xxx为项目名称(与你的项目配置相关,具体配置方式见上一篇文章) 2.OC类里仅可以调用public的Swift...
1 2 3 4 5 ... 20
收藏数 9,323
精华内容 3,729
关键字:

oc 项目调用swift