Quantcast
Channel: CSDN博客移动开发推荐文章
Viewing all articles
Browse latest Browse all 5930

8、Plugin.xml(基础知识)

$
0
0

翻译自cordova官方文档(如果需要链接,请自行对照原文链接进行查看):
https://cordova.apache.org/docs/en/latest/plugin_ref/spec.html

Plugin.xml

Plugin.xml是用于设置你得插件,他包含很多元素为你的插件提供详细的设置。

<pluginxmlns="http://apache.org/cordova/ns/plugins/1.0"id="cordova-plugin-splashscreen"version="3.2.0"><!--
        plugin 标签是Plugin配置文件最顶层的元素
            xmlns:用于指定命名空间(namespace),当然也可以指定针对特定平台的命名空间比如
                xmlns:android="http://schemas.android.com/apk/res/android"
               id:用于设置plugin的识别id
          version:plugin的版本号
    --><name>Splashscreen</name><!--
            用于为plugin设定一个名字。
        --><description>Cordova Splashscreen Plugin</description><!--
            plugin的描述或者说明
        --><license>Apache 2.0</license><!--
            为plugin指定使用哪种开源许可license
        --><keywords>cordova,splashscreen</keywords><!--
            使用逗号分割,用于描述plugin的关键字。
        --><author>Foo plugin author</author><!--
            用于设置作者信息。
            # 这个是为了解释这个标签特地加入的,并不是splashscreen插件带的。
        --><assetsrc="www/new-foo.js"target="js/experimental/foo.js" /><!--
            将特定js文件拷贝到工程指定目录。并且可以重命名。
            # 这个是为了解释这个标签特地加入的,并不是splashscreen插件带的。
        --><repo>https://git-wip-us.apache.org/repos/asf/cordova-plugin-splashscreen.git</repo><!--
            plugin的描述或者说明
        --><issue>https://issues.apache.org/jira/browse/CB/component/12320653</issue><dependencyid="cordova-plugin-someplugin"url="https://github.com/myuser/someplugin"commit="428931ada3891801"subdir="some/path/here" /><dependencyid="cordova-plugin-someplugin"version="1.0.1"><!--
            用于声明该plugin会依赖其他plugin,通过id或者是url来指定依赖plugin的源。
        --><engines><enginename="cordova-android"version=">=3.6.0" /><!-- Requires CordovaPlugin.preferences --></engines><!--
            engines用于设置plugin适用的平台镜像版本
            engine用于设置具体支持的版本,name用于指定镜像平台,version用于设置版本号
            ,如果不设置默认支持全平台全版本
            目前cordova支持的平台主要如下:
            .cordova
            .cordova-plugman
            .cordova-android
            .cordova-ios
            .cordova-blackberry10
            .cordova-wp8
            .cordova-windows
            .cordova-osx
            .windows-os
            .android-sdk (returns the highest Android api level installed)
            .windows-sdk (returns the native windows SDK version)
            .apple-xcode (returns the xcode version)
            .apple-ios (returns the highest iOS version installed)
            .apple-osx (returns the OSX version)
            .blackberry-ndk (returns the native blackberry SDK version)
        --><js-modulesrc="www/splashscreen.js"name="SplashScreen"><clobberstarget="navigator.splashscreen" /></js-module><!--
            js-module标签一般用于发布定义js接口的js文件。本例中,将www/splashscreen.js文件中定义的接口发布到
            window.navigator.splashscreen对象上,这样web端可以直接通过navigator.splashscreen对象来访问plugin
            的api。如果想替换掉window对象上指定接口还可以通过以下方式:
            <js-module src="socket.js" name="Socket">
                <merges target="chrome.socket" />
                # 使用merges标签,如果chrome.socket存在,那么用此plugin内的chrome.socket替换掉原有的。
            </js-module>
            <js-module src="socket.js" name="Socket">
                <runs/>
                # 使用runs标签你代码需要通过cordova.require去指定,并且不是安装到window对象上。
                这个标签用于安装模块或者是其他的时候使用。该标签和<clobbers/>或者<merges/>一起使用是多余的。
            </js-module>
        --><!--
        platform用于指定plugin安装到哪些平台,这里主要介绍android和ios,如果没有指定平台,那么cordova会把plugin看
        做只提供javascript接口的plugin。
                 name:用于指定平台名字。
          source-file:用于告诉plugin把config-file包含的内容安装到target里面。或者是target-dir里面。
          header-file:同样也是用来将指定文件拷贝到指定目录下。
        resource-file:同样也是用于拷贝文件,不同的是这个配置用于拷贝非代码资源。
                  <resource-file src="FooPluginStrings.xml" target="res/values/FooPluginStrings.xml" />
          config-file:指定需要设置的配置文件爱你,比如xml或者plist,添加进去的内容必须以xml的格式设置。
                  具体参见下面例子代码。其中parent用于指定在哪一个父元素下添加。
        plugins-plist:已经过时了。现在使用<config-file>来替代。
             lib-file: 用于添加依赖包。
                     <lib-file src="src/BlackBerry10/native/device/libfoo.so" arch="device" />
                     src用于指定plugin下的文件路径,arch用于设置依赖包需要的架构比如x86,x64,
                     device-target用于设置目标设备win,phone,all.
           framework:用于引入一个依赖framework。
                  <framework src="libsqlite3.dylib" />
                  <framework src="com.google.android.gms:play-services-gcm:+" />
                  <framework src="relative/path/rules.gradle" custom="true" type="gradleReference" />
                  <framework src="path/to/project/LibProj.csproj" custom="true" type="projectReference"/>
                  <framework src="src/windows/example.dll" arch="x64" />
                info:提供一些额外信息。说明信息之类的。
                hook:用于设置在cordova某些命令执行后需要执行的脚本比如
                         <hook type="after_plugin_install" src="scripts/afterPluginInstall.js" />   
                         具体参照[Hooks](https://cordova.apache.org/docs/en/latest/guide/appdev/hooks/index.html)
             uses-permission:用来声明plugin需要申请的权限,比如:
                     <uses-permission android:name="my-app-id.permission.C2D_MESSAGE"/>
              preference:用于在安装plugin的时候check用户设置的变量,如果变量的内容不正确,显示警告信息
                 <preference name="API_KEY" default="default-value" />
                 比如在statusbar插件中的设置
                 <config-file target="config.xml" parent="/*">
                    <feature name="StatusBar">
                        <param name="ios-package" value="CDVStatusBar" />
                        <param name="onload" value="true" />
                    </feature>
                    <preference name="StatusBarOverlaysWebView" value="true" />
                    <preference name="StatusBarStyle" value="lightcontent" />
                 </config-file>
        --><!-- android --><platformname="android"><!-- 修改AndroidManifest.xml文件 
                <config-file target="AndroidManifest.xml" parent="/manifest">
                     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
                </config-file>--><config-filetarget="res/xml/config.xml"parent="/*"><!--在androidn的config.xml中添加feature内的配置信息--><featurename="SplashScreen"><paramname="android-package"value="org.apache.cordova.splashscreen.SplashScreen"/><paramname="onload"value="true"/></feature></config-file><!--将指定文件安装到target-dir的位置--><source-filesrc="src/android/SplashScreen.java"target-dir="src/org/apache/cordova/splashscreen" /><!--将依赖的jar添加到系统--><!--<source-file src="plugin_path/**.jar" target-dir="libs" />--></platform><!-- ios --><platformname="ios"><config-filetarget="config.xml"parent="/*"><!--在config.xml中添加feature内的配置信息--><featurename="SplashScreen"><paramname="ios-package"value="CDVSplashScreen"/><paramname="onload"value="true"/></feature></config-file><!--为了举例添加的例子代码--><config-filetarget="helloworld-Info.plist"parent="CFBundleURLTypes"><array><dict><key>PackageName</key><string>$PACKAGE_NAME</string></dict></array></config-file><header-filesrc="src/ios/CDVSplashScreen.h" /><source-filesrc="src/ios/CDVSplashScreen.m" /><header-filesrc="src/ios/CDVViewController+SplashScreen.h" /><source-filesrc="src/ios/CDVViewController+SplashScreen.m" /><frameworksrc="CoreGraphics.framework" /></platform></plugin>
作者:zzh_receive 发表于2016/11/16 21:03:30 原文链接
阅读:8 评论:0 查看评论

Viewing all articles
Browse latest Browse all 5930

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>