iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >如何在IOS中使用Cordova插件
  • 379
分享到

如何在IOS中使用Cordova插件

IOSCordova插件 2022-05-23 01:05:21 379人浏览 泡泡鱼
摘要

目录一、准备1:创建插件2:添加IOS平台3:创建package.json文件二、过程最后Cordova项目调用插件一、准备 插件功能:打开iOS相机 1:创建插件 plugman

一、准备

插件功能:打开iOS相机

1:创建插件

plugman create --name [插件名称] --plugin_id [插件ID] --plugin_version [插件版本号] plugman create --name CameraDemo --plugin_id cordova-plugin-camerademo --plugin_version 1.0.0

2:添加IOS平台

plugman platfORM add --platform_name ios

3:创建package.JSON文件

以下两种都可以生成package.json 1:使用命令 “npm init” 创建package.json文件 2:plugman createpackagejson [插件路径] 原应用使用的ionic UI框架,没有package.json无法安装插件

最终插件目录结构

除了ViewController.h和ViewController.m文件,其余的文件通过上述步骤都会自动生成

二、过程

创建文件ViewController.h和ViewController.m ViewController.h


#import <UIKit/UIKit.h>

@interface ViewController : UIViewController{
}
@property (nonatomic,strong) UIImagePickerController *imagePicker;
- (void)getDeviceInfo;  //获取ios设备信息
- (void)OpenCamera;		//打开ios相机
@end

ViewController.m


#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController
- (id) init{
    NSLog(@"=======================相机初始化");
    self = [super init];
    self.imagePicker = [[UIImagePickerController alloc] init];
    return self;
}

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    
    UIButton *button =[[UIButton alloc]init];
    [button setTitle:@"我是按钮" forState:(UIControlStateNormal)];
    [button setTitleColor:[UIColor redColor] forState:(UIControlStateNormal)];
    [button setTitleColor:[UIColor blueColor] forState:(UIControlStateHighlighted)];
    [button setBackgroundColor:[UIColor yellowColor]];
    [button setFrame:CGRectMake(10, 50, 100, 30)];
    //事件
    //[button addTarget:self action:@selector(click) forControlEvents:(UIControlEventTouchUpInside)];
    [self.view addSubview:button];
    
    UIButton *deviceBtn =[[UIButton alloc]init];
    [deviceBtn setTitle:@"查看设备信息" forState:(UIControlStateNormal)];
    [deviceBtn setTitleColor:[UIColor redColor] forState:(UIControlStateNormal)];
    [deviceBtn setTitleColor:[UIColor blueColor] forState:(UIControlStateHighlighted)];
    [deviceBtn setBackgroundColor:[UIColor yellowColor]];
    [deviceBtn setFrame:CGRectMake(120, 50, 200, 30)];
    [deviceBtn addTarget:self action:@selector(getDeviceInfo) forControlEvents:(UIControlEventTouchUpInside)];
    [self.view addSubview:deviceBtn];
    
    UIButton *openCameraBtn =[[UIButton alloc]init];
    [openCameraBtn setTitle:@"打开相机" forState:(UIControlStateNormal)];
    [openCameraBtn setTitleColor:[UIColor redColor] forState:(UIControlStateNormal)];
    [openCameraBtn setTitleColor:[UIColor blueColor] forState:(UIControlStateHighlighted)];
    [openCameraBtn setBackgroundColor:[UIColor yellowColor]];
    [openCameraBtn setFrame:CGRectMake(330, 50, 200, 30)];
    [openCameraBtn addTarget:self action:@selector(openCamera) forControlEvents:(UIControlEventTouchUpInside)];
    [self.view addSubview:openCameraBtn];
    
    
}

- (void)getDeviceInfo{
    NSLog(@"获取设备信息。。。。");
    NSString *name = [[UIDevice currentDevice] name];
    NSString *systemName = [[UIDevice currentDevice] systemName];
    NSString *systemVersion = [[UIDevice currentDevice] systemVersion];
    NSString *model = [[UIDevice currentDevice] model];
    NSString *localizeModel = [[UIDevice currentDevice] localizedModel];
    
    UILabel *nameL = [[UILabel alloc] init];
    UILabel *systemNameL = [[UILabel alloc] init];
    UILabel *systemVersionL = [[UILabel alloc] init];
    UILabel *modelL = [[UILabel alloc] init];
    UILabel *localizeModelL = [[UILabel alloc] init];
    
    [nameL setText:name];
    [systemNameL setText:systemName];
    [systemVersionL setText:systemVersion];
    [modelL setText:model];
    [localizeModelL setText:localizeModel];
    
    [nameL setTextColor:[UIColor blueColor]];
    [systemNameL setTextColor:[UIColor blueColor]];
    [systemVersionL setTextColor:[UIColor blueColor]];
    [modelL setTextColor:[UIColor blueColor]];
    [localizeModelL setTextColor:[UIColor blueColor]];
    
    CGFloat x = 10;
    CGFloat y = 80;
    CGFloat width = 200;
    CGFloat height=20;
    
    nameL.frame = CGRectMake(x, y+20, width, height);
    systemNameL.frame = CGRectMake(x, y+40, width, height);
    systemVersionL.frame = CGRectMake(x, y+60, width, height);
    modelL.frame = CGRectMake(x, y+80, width, height);
    localizeModelL.frame = CGRectMake(x, y+100, width, height);
    
    [self.view addSubview:nameL];
    [self.view addSubview:systemNameL];
    [self.view addSubview:systemVersionL];
    [self.view addSubview:modelL];
    [self.view addSubview:localizeModelL];
}

- (void)openCamera{
    //NSLog(@"打开摄像头。。。。");
    //UIImagePickerController *imagePicker = [[UIImagePickerController alloc] init];
    self.imagePicker.editing = YES;
    self.imagePicker.delegate = self;
    self.imagePicker.allowsEditing = YES;
    
    if([UIImagePickerController isSourceTypeAvailable:UIImagePickerControllerSourceTypeCamera]){
        NSLog(@"选择相机。。。");
        self.imagePicker.sourceType = UIImagePickerControllerSourceTypeCamera;
    }
    
    [self presentViewController:self.imagePicker animated:YES completion:nil];
}
@end

这两个文件其实是我已经在ios原生项目下编译运行过的文件,然后被CameraDemo.m调用。(其实有点类似于库的作用)

直白一点就是。有一个库(ViewController.h和ViewController.m),提供了一个类ViewController,这个类提供了两个方法

  • (void)getDeviceInfo; //获取ios设备信息
  • (void)OpenCamera; //打开ios相机

然后CameraDemo.m去实例化了这个类 CameraDemo.m




#import <Cordova/CDV.h>
#import "ViewController.h"

//这里必须继承CDVPlugin 类,表示CameraDemo是Cordova插件类
@interface CameraDemo : CDVPlugin {
  // Member variables Go here.
}
@property (nonatomic,strong) ViewController *view;  //声明一个ViewController
- (void)coolMethod:(CDVInvokedUrlCommand*)command;  //创建插件自带的方法,可以删除
- (void)openCamera:(CDVInvokedUrlCommand*)command;
@end

@implementation CameraDemo

- (void)pluginInitialize{
    NSLog(@"===========================初始化CameraDemo");
    [super pluginInitialize];
    // 实例化ViewController 
    self.view = [[ViewController alloc] init];
}

//创建插件自带的方法,可以删除
- (void)coolMethod:(CDVInvokedUrlCommand*)command
{
    CDVPluginResult* pluginResult = nil;
    NSString* echo = [command.arguments objectAtIndex:0];

    if (echo != nil && [echo length] > 0) {
        pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsString:echo];
    } else {
        pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR];
    }

    [self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
}

- (void)openCamera:(CDVInvokedUrlCommand*)command
{
	// 将ViewController的实例viewController  显示出来
    [self.viewController presentViewController:self.view animated:YES completion:nil];
    //ViewController *view = [[ViewController alloc] init];
    //[view openCamera];
    //CDVPluginResult* pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR];;
    //[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
}
@end

CameraDemo.js


var exec = require('cordova/exec');

exports.coolMethod = function (arg0, success, error) {
    exec(success, error, 'CameraDemo', 'coolMethod', [arg0]);
};

exports.openCamera = function (arg0, success, error) {
    exec(success, error, 'CameraDemo', 'openCamera', [arg0]);
};

plugin.xml (这个文件非常非常的重要,js可以调用oc全靠它,多查查资料)


<?xml version='1.0' encoding='utf-8'?>
<plugin id="cordova-plugin-camerademo" version="1.0.0"
    xmlns="Http://apache.org/cordova/ns/plugins/1.0"
    xmlns:Android="http://schemas.android.com/apk/res/android">
    <name>CameraDemo</name>
    <js-module name="CameraDemo" src="www/CameraDemo.js">
        <clobbers target="cordova.plugins.CameraDemo" />
    </js-module>

    <platform name="ios">
        <config-file parent="/*" target="config.xml">
            <feature name="CameraDemo">
                <param name="ios-package" value="CameraDemo" onload="true"/>
            </feature>
        </config-file>
        <source-file src="src/ios/CameraDemo.m" />
        <header-file src="src/ios/ViewController.h" />
        <source-file src="src/ios/ViewController.m" />
    </platform>
</plugin>

package.json (一般不需要修改)


{
  "name": "cordova-plugin-camerademo",
  "version": "1.0.0",
  "description": "",
  "cordova": {
    "id": "cordova-plugin-camerademo",
    "platforms": [
      "ios"
    ]
  },
  "keyWords": [
    "ecosystem:cordova",
    "cordova-ios"
  ],
  "author": "",
  "license": "ISC"
}

CameraDemo.js 通过 plugin.xml 配置去调用了原生的ocject-c方法

最后

Cordova项目调用插件

重要,如果调用和插件中的plugin.xml配置有关,所以plugin.xml非常重要


// 在项目的 ts文件中调用
declare let cordova:any
cordova.plugins.CameraDemo.openCamera();

以上就是如何在IOS中使用Cordova插件的详细内容,更多关于IOS使用Cordova的资料请关注编程网其它相关文章!

--结束END--

本文标题: 如何在IOS中使用Cordova插件

本文链接: https://www.lsjlt.com/news/30477.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何在IOS中使用Cordova插件
    目录一、准备1:创建插件2:添加IOS平台3:创建package.json文件二、过程最后Cordova项目调用插件一、准备 插件功能:打开IOS相机 1:创建插件 plugman ...
    99+
    2022-05-23
    IOS Cordova 插件
  • 怎么在IOS中使用Cordova插件
    这篇文章给大家分享的是有关怎么在IOS中使用Cordova插件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、准备插件功能:打开IOS相机1:创建插件plugman create --name [插件名称] -...
    99+
    2023-06-14
  • 如何在IDEA中使用FindBugs插件
    本篇文章为大家展示了如何在IDEA中使用FindBugs插件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。安装 安装完之后,重启studio,会发现左下角会出现findbugs的图标可以分...
    99+
    2023-06-14
  • 如何在IOS中使用IBeacon
    什么是iBeacon? iBeacon 是苹果公司2013年9月发布的移动设备用OS(iOS7)上配备的新功能。其工作方式是,配备有低功耗蓝牙(BLE)通信功能的设备使用BLE技术向...
    99+
    2022-05-25
    IOS IBeacon
  • 如何在Android应用中使用Jenkins插件
    今天就跟大家聊聊有关如何在Android应用中使用Jenkins插件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、Jenkins插件功能介绍Jenkins任务列表图1、jenki...
    99+
    2023-05-31
    android roi jenkins
  • 如何在HTML5中使用video.js视频播放插件
    本篇文章给大家分享的是有关如何在HTML5中使用video.js视频播放插件,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。看下默认例子:controls表示控制条,prload...
    99+
    2023-06-09
  • Python中PyDev插件如何使用
    Python中PyDev插件如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。验证是否成功安装 PyDev如何才能验证 Eclipse Update Manager 是否已...
    99+
    2023-06-17
  • VSCode中如何使用FreeWindow插件
    这期内容当中小编将会给大家带来有关VSCode中如何使用FreeWindow插件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。FreeWindow插件的图标是一条鱼,中间有一个“摸”字,是摸鱼的意思。原理...
    99+
    2023-06-20
  • Elasticsearch中Head插件如何使用
    本篇内容主要讲解“Elasticsearch中Head插件如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Elasticsearch中Head插件如何使用”吧!基础环境系统 节点名 IP ...
    99+
    2023-06-28
  • MySQL中如何使用NoSQL插件
    本篇文章为大家展示了MySQL中如何使用NoSQL插件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  MySql基本安装步骤:   ...
    99+
    2022-10-18
  • Struts2 中json插件如何使用
    今天就跟大家聊聊有关Struts2 中json插件如何使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。***步:在struts2基本jar包的基础上添加struts2-jsonpl...
    99+
    2023-06-17
  • VSCode中Snippet插件如何使用
    这篇文章主要介绍“VSCode中Snippet插件如何使用”,在日常操作中,相信很多人在VSCode中Snippet插件如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VSCode中Snippet插件如...
    99+
    2023-07-04
  • Elasticsearch中如何使用Head插件
    Elasticsearch中如何使用Head插件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、安装由于插件时托管在github中,要从github中直接下载所以需要先安...
    99+
    2023-06-04
  • 怎么在python中使用vim插件
    怎么在python中使用vim插件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Python的优点有哪些1、简单易用,与C/C++、Java、C# 等传统语言相比,Pyth...
    99+
    2023-06-14
  • tree插件怎么在centos中使用
    这篇文章给大家介绍tree插件怎么在centos中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。tree的安装: yum -y install tree 或者是 sudo apt-get install tree ...
    99+
    2023-06-10
  • 如何使用PDF.JS插件实现在HTML中预览PDF文件
    这篇文章给大家分享的是有关如何使用PDF.JS插件实现在HTML中预览PDF文件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。PDF.js是一款基于HTML5建立的PDF阅读器,...
    99+
    2022-10-19
  • 如何在laravel-admin中使用wang-editor富文本插件
    本篇文章为大家展示了如何在laravel-admin中使用wang-editor富文本插件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。composer 添加“laravel-admin-ext/w...
    99+
    2023-06-15
  • lightbox.js插件如何使用
    要使用lightbox.js插件,您需要按照以下步骤进行操作:1. 下载lightbox.js插件文件,并将其包含在您的HTML文件...
    99+
    2023-08-24
    lightbox.js
  • Vue插件如何使用
    这篇文章主要介绍了Vue插件如何使用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Vue插件1、概述简单来说,插件就是指对Vue的功能的增强...
    99+
    2022-10-19
  • MySQL中如何使用Connection-Control插件
    这期内容当中小编将会给大家带来有关MySQL中如何使用Connection-Control插件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。首先查看系统变量plugin_...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作