andriod 源码开发,打包so到apk

 命令方式将so文件打包进apk
        使用android SDK原代码 开发APK,将so文件打包进apk,这样可以只提供给客户一个apk.
1.        含义全代码的so打包.
a)        建立工程,并使用本地调用,java文件如下
package test.jni;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class jnitest extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        TextView  tv = new TextView(this);
        int       x  = 55;
        int       y  = 8;
        System.loadLibrary("apptest");
        //System.loadLibrary("testapi");
        int  z = appadd(x, y);
        tv.setText( x + "+" + y + "=" + z );
        setContentView(tv);
    }
    public native int appadd(int  x, int  y);
}
b)        在工程的根目录建立Android.mk,内容如下.
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := user eng
LOCAL_SRC_FILES := $(call all-subdir-java-files)
LOCAL_PACKAGE_NAME := jnitest
LOCAL_JNI_SHARED_LIBRARIES := libapptest
include $(BUILD_PACKAGE)
include $(LOCAL_PATH)/jni/Android.mk
# Use the folloing include to make our test apk.
include $(call all-makefiles-under,$(LOCAL_PATH))
其中LOCAL_MODULE_TAGS名字要和目标系统一致,否则编译产生的apk文件不能安装到目标系统,.
LOCAL_JNI_SHARED_LIBRARIES := libapptest 把我们另外编译成的so文件放到apk文件里的libs/armeabi里
include $(LOCAL_PATH)/jni/Android.mk为了编译本地文件成为so
c)        在工程根目录创建jni文件夹,在jni文件里创建Android.mk和callapp.c,他们内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := user eng
LOCAL_MODULE    := libapptest
LOCAL_SRC_FILES := callapp.c
LOCAL_C_INCLUDES += \
        $(JNI_H_INCLUDE)
LOCAL_PRELINK_MODULE := false
include $(BUILD_SHARED_LIBRARY)
LOCAL_MODULE_TAGS :要和工程的一致,否则编译不通过
LOCAL_C_INCLUDES += \
        $(JNI_H_INCLUDE)  为了让jni编译通过,因为工程通过jni调用本地库
#include <jni.h>
JNIEXPORT jint JNICALL Java_test_jni_jnitest_appadd
  (JNIEnv *env, jobject obj, jint x, jint y){
    return x +y;
}
d)        把工程文件放到SDK platform\packages\apps目录下,然后进入该目录,命令里输入mm,进行该工程的编译.(之前要再platform之前把工程目标设定好)
e)        编译出来的apk 在platform/out/target/product/sk886x/system/app里可以找到,其中sk886x 是目标平台. 打开该apk文件,可以看到libapptest.so存在在包里的libs/armeabi文件夹里. 运行该apk,可以正常运行,显示正确答案.
2.        本地库so文件里加打印消息.
a)        这样修改jni文件夹下Android.mk.添加
LOCAL_SHARED_LIBRARIES := libutils
b)        Callapp.c如下
#include <jni.h>
#define LOG_TAG "TestThunderLib"
#undef LOG
#include <utils/Log.h>
JNIEXPORT jint JNICALL Java_test_jni_jnitest_appadd
  (JNIEnv *env, jobject obj, jint x, jint y){
          LOGD("TEST %d+%d=%d",x,y,x+y);
    return x+y;//add22(x,y);
}
c)        重新再工程根目录输入mm,编译得到apk,运行到目标机,通过uart 敲入命令 logcat,会发现有 log 输出 TEST 55 + 66 = 121 等正确信息
3.        在以上的基础上,我引进另外的库文件,给callapp.c调用.
a)        此库我们用NDK 编译出来,请保证和目标平台版本一致.文件如下:
i.        Add.c
#include "add.h"
int  add22(int  x, int  y){
    return x + y;
}
ii.        Add.h
#ifndef ADD_H
#define ADD_H

extern int add22(int  x, int  y);

#endif /* ADD_H */
iii.        NDK 的Android.mk
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE    := testapi
LOCAL_SRC_FILES := add.c
LOCAL_PRELINK_MODULE := false
include $(BUILD_STATIC_LIBRARY)
#include $(BUILD_SHARED_LIBRARY)
b)        选择不同的built方式,经NDK 编译,可以得到libtestapi.a,libtestapi.so
c)        此时,工程目录下jni文件夹里Android.mk里添加
LOCAL_STATIC_LIBRARIES := libtestapi
表示吧libtestapi作为静态库编译到libapptest.so里.
d)        Callapp.c 内容如下
#include <jni.h>
#include "add.h"
#define LOG_TAG "TestThunderLib"
#undef LOG
#include <utils/Log.h>
JNIEXPORT jint JNICALL Java_test_jni_jnitest_appadd
  (JNIEnv *env, jobject obj, jint x, jint y){
          LOGD("TEST %d+%d=%d",x,y,x+y);
    return add22(x,y);
}
e)        在工程根目录下输入mm,编译提示out/target/product/sk886x/obj/STATIC_LIBRARIES/libtestapi_intermediates/libtestapi.a 找不到,这时候我们把b)得到的libtestapi.a放到提示的文件夹里,再重新编译就通过.得到的apk,安装到目标机,运行,成功.
4.        在步骤3的基础上,我们让callapp.c调用libtesapi.so
a)        修改工程根目录,android.mk
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := user eng
LOCAL_SRC_FILES := $(call all-subdir-java-files)
LOCAL_PACKAGE_NAME := jnitest
LOCAL_JNI_SHARED_LIBRARIES := libapptest libtestapi
include $(BUILD_PACKAGE)
include $(LOCAL_PATH)/jni/Android.mk
# Use the folloing include to make our test apk.
include $(call all-makefiles-under,$(LOCAL_PATH))注意libapptest libtestapi 要同一行,否则,前面一个不会打包到apk里.
b)        Jni目录下Android.mk 里添加
        LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := user eng
LOCAL_MODULE    := libapptest
LOCAL_SRC_FILES := callapp.c
LOCAL_C_INCLUDES += \
        $(JNI_H_INCLUDE)
LOCAL_SHARED_LIBRARIES := libutils libtestapi
#LOCAL_STATIC_LIBRARIES := libtestapi
LOCAL_LDLIBS := -ldl -llog
LOCAL_PRELINK_MODULE := false
include $(BUILD_SHARED_LIBRARY)               
c)        编译,提示找不到libtestapi.so,我们把他分别复制到out/target/product/sk886x/obj/lib/和/out/target/product/sk886x/system/lib/ 这样能编译通过.
d)        运行apk,发现提示错误.由于libtestapi.so 是我们以动态共享库提供给libapptest.so,所以libtestapi.so要放到/system/lib里,通过adb push 到/system/lib以后,重新运行apk,可以正确运行.
内容概要:本研究聚焦于绿电直连型电氢氨园区的优化运行,提出一种集成绿色电力直接供给、电解水制氢及氢气合成氨工艺的综合能源系统架构。通过建立含风光发电、电解槽、氨合成反应器、储氢罐、电网交互及多类型负荷在内的系统模型,综合考虑绿电直供优先、能量梯级利用与多能互补原则,构建以系统综合运行成本最小化为目标的优化调度模型。研究采用Matlab与Python工具进行算法求解和仿真分析,利用实际气象与负荷数据完成案例验证,评估了不同运行策略下系统的经济性、可再生能源消纳能力与碳减排效益,为新型电氢氨一体化园区的规划与运行提供了理论依据和技术支撑。; 适合人群:具备一定电力系统、新能源或化工背景的研究生、科研人员及从事综合能源系统规划与优化工作的工程技术人员。; 使用场景及目标:①用于科研学习,理解电-氢-氨多能转换系统的建模与优化方法;②为工业园区的低碳化、智能化改造提供技术参考与决策支持;③作为开发类似综合能源管理系统的理论基础。; 阅读建议:此资源含完整的模型代码、数据与论文,使用者应结合代码仔细研读论文中的模型构建部分,重点关注目标函数与约束条件的设计逻辑,并尝试修改参数进行仿真,以深入掌握优化算法在实际系统中的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值