Kanzi for Android Demo

新建HelloKanzi工程

拷贝kzb等文件到assets目录

/.../app/src/main/assets$ tree -l
.
├── a55testapplication.kzb
├── application.cfg
├── data.xml
├── tsview.kzb.cfg
└── tsview.kzb.txt

其中data.xml文件的接口描述文件:

assets$ cat data.xml 
<speed type = "int">1</speed>

引入Kanzi依赖库

拷贝文件:

app/src/main/libs$ tree -l
.
├── AndroidDataSource.jar
├── kanzi_engine.jar
└── arm64-v8a
    ├── libc++_shared.so
    ├── libkanzi.so
    ├── libkzandroiddatasource.so
    ├── libkzappmanager.so
    ├── libkzcore.so
    ├── libkzcoreui.so
    ├── libkzparticlesystem.so
    └── libkzui.so

在build.gradle中引入依赖:

android {
    defaultConfig {
        ...
        ndk {
            abiFilters 'arm64-v8a'    //只生成armv8的so
        }
    }

    sourceSets {
        main {
            jniLibs.srcDirs = ['libs']
        }
    }
    aaptOptions {
        noCompress "cfg","kzb"
    }
}

dependencies {
    ...
    implementation files('libs/AndroidDataSource.jar')
    implementation files('libs/kanzi_engine.jar')
    ...
}

修改MainAcitivity代码

package com.xxx.hellokanzi;

import android.content.Context;
import android.os.Bundle;
import android.util.Log;

import com.rightware.kanzi.KanziActivity;
import com.rightware.kanzi.androiddatasource.AndroidDataSourceManager;
import com.rightware.kanzi.androiddatasource.BaseManager;
import com.rightware.kanzi.androiddatasource.SharedData;
import com.rightware.kanzi.androiddatasource.kzDataTypeInt;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

public class MainActivity extends KanziActivity {

    private static final String TAG = "KanziActivity";

    AndroidDataSourceManager mDataFeeder;

    @Override
    protected void onCreate(Bundle bundle) {
        super.onCreate(bundle);

        String kanziConfigPath = getFilesDir().getAbsolutePath();

        copyAssetsToDst(this, "data.xml", kanziConfigPath + File.separator + "data.xml");

        mDataFeeder = new AndroidDataSourceManager("AndroidDataSourceManager");
        SharedData.get().addManager((BaseManager) mDataFeeder);

        try {
            mDataFeeder.setXMLPath(kanziConfigPath + File.separator);
        } catch (Exception exception) {
            Log.e(TAG, exception.toString());
        }


        queueEvent(new Runnable() {
            @Override
            public void run() {
                if (mDataFeeder == null) {
                    return;
                }
                kzDataTypeInt intDataType = new kzDataTypeInt("speed");
                mDataFeeder.getKanziController().setDataObjectValue(intDataType, 100);
            }
        });
    }

    private void copyAssetsToDst(Context context, String srcPath, String dstPath) {

        try {
            InputStream is = context.getAssets().open(srcPath);
            FileOutputStream fos = new FileOutputStream(new File(dstPath));
            byte[] buffer = new byte[1024];

            int byteCount;
            while ((byteCount = is.read(buffer)) != -1) {
                fos.write(buffer, 0, byteCount);
            }

            fos.flush();
            is.close();
            fos.close();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

    @Override
    protected void onDestroy() {
        super.onDestroy();

        if (mDataFeeder == null) {
            return;
        }

        SharedData.get().removeManager();
        mDataFeeder.delete();
    }
}

显示效果

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
可以使用Android中提供的SyncAdapter框架来实现CalDAV同步,以下是一个简单的CalDAV Demo: 1. 创建SyncAdapter ```java public class CalDavSyncAdapter extends AbstractThreadedSyncAdapter { private final AccountManager mAccountManager; public CalDavSyncAdapter(Context context, boolean autoInitialize) { super(context, autoInitialize); mAccountManager = AccountManager.get(context); } @Override public void onPerformSync(Account account, Bundle extras, String authority, ContentProviderClient provider, SyncResult syncResult) { //TODO: 实现CalDAV同步逻辑 } } ``` 2. 在AndroidManifest.xml中注册SyncAdapter ```xml <service android:name=".CalDavSyncAdapter" android:exported="true" android:process=":sync"> <intent-filter> <action android:name="android.content.SyncAdapter" /> </intent-filter> <meta-data android:name="android.content.SyncAdapter" android:resource="@xml/syncadapter" /> </service> ``` 3. 在res/xml目录下创建syncadapter.xml文件,指定SyncAdapter的属性 ```xml <sync-adapter xmlns:android="http://schemas.android.com/apk/res/android" android:accountType="com.example.caldav" android:userVisible="true" android:supportsUploading="true" android:allowParallelSyncs="false" android:isAlwaysSyncable="true" /> ``` 4. 在MainActivity中创建账户并启动同步 ```java public class MainActivity extends AppCompatActivity { private Account mAccount; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mAccount = new Account("username", "com.example.caldav"); AccountManager accountManager = AccountManager.get(this); accountManager.addAccountExplicitly(mAccount, null, null); ContentResolver.setIsSyncable(mAccount, "com.android.calendar", 1); ContentResolver.setSyncAutomatically(mAccount, "com.android.calendar", true); ContentResolver.addPeriodicSync(mAccount, "com.android.calendar", new Bundle(), 60); } } ``` 5. 实现CalDAV同步逻辑 ```java private void syncCalendars(Account account) { CalDavAccount calDavAccount = getCalDavAccount(account); List<CalDavCalendar> remoteCalendars = getRemoteCalendars(calDavAccount); List<CalDavCalendar> localCalendars = getLocalCalendars(account); for (CalDavCalendar remoteCalendar : remoteCalendars) { if (!localCalendars.contains(remoteCalendar)) { createLocalCalendar(account, remoteCalendar); } else { updateLocalCalendar(account, remoteCalendar); } } for (CalDavCalendar localCalendar : localCalendars) { if (!remoteCalendars.contains(localCalendar)) { deleteLocalCalendar(account, localCalendar); } } } private CalDavAccount getCalDavAccount(Account account) { String username = account.name; String password = AccountManager.get(this).getPassword(account); //TODO: 创建CalDavAccount对象 } private List<CalDavCalendar> getRemoteCalendars(CalDavAccount calDavAccount) { //TODO: 获取远程CalDAV服务器上的日历列表 } private List<CalDavCalendar> getLocalCalendars(Account account) { List<CalDavCalendar> localCalendars = new ArrayList<>(); Cursor cursor = getContentResolver().query(Calendars.CONTENT_URI, null, Calendars.ACCOUNT_NAME + " = ? AND " + Calendars.ACCOUNT_TYPE + " = ?", new String[]{account.name, account.type}, null); while (cursor.moveToNext()) { String name = cursor.getString(cursor.getColumnIndex(Calendars.NAME)); String displayName = cursor.getString(cursor.getColumnIndex(Calendars.CALENDAR_DISPLAY_NAME)); String description = cursor.getString(cursor.getColumnIndex(Calendars.CALENDAR_DESCRIPTION)); String timeZone = cursor.getString(cursor.getColumnIndex(Calendars.CALENDAR_TIME_ZONE)); int color = cursor.getInt(cursor.getColumnIndex(Calendars.CALENDAR_COLOR)); int accessLevel = cursor.getInt(cursor.getColumnIndex(Calendars.CALENDAR_ACCESS_LEVEL)); boolean syncEvents = cursor.getInt(cursor.getColumnIndex(Calendars.SYNC_EVENTS)) == 1; //TODO: 创建CalDavCalendar对象并添加到localCalendars列表中 } cursor.close(); return localCalendars; } private void createLocalCalendar(Account account, CalDavCalendar remoteCalendar) { ContentValues values = new ContentValues(); values.put(Calendars.ACCOUNT_NAME, account.name); values.put(Calendars.ACCOUNT_TYPE, account.type); values.put(Calendars.NAME, remoteCalendar.getName()); values.put(Calendars.CALENDAR_DISPLAY_NAME, remoteCalendar.getDisplayName()); values.put(Calendars.CALENDAR_DESCRIPTION, remoteCalendar.getDescription()); values.put(Calendars.CALENDAR_TIME_ZONE, remoteCalendar.getTimeZone()); values.put(Calendars.CALENDAR_COLOR, remoteCalendar.getColor()); values.put(Calendars.CALENDAR_ACCESS_LEVEL, remoteCalendar.getAccessLevel()); values.put(Calendars.SYNC_EVENTS, 1); getContentResolver().insert(Calendars.CONTENT_URI, values); } private void updateLocalCalendar(Account account, CalDavCalendar remoteCalendar) { ContentValues values = new ContentValues(); values.put(Calendars.NAME, remoteCalendar.getName()); values.put(Calendars.CALENDAR_DISPLAY_NAME, remoteCalendar.getDisplayName()); values.put(Calendars.CALENDAR_DESCRIPTION, remoteCalendar.getDescription()); values.put(Calendars.CALENDAR_TIME_ZONE, remoteCalendar.getTimeZone()); values.put(Calendars.CALENDAR_COLOR, remoteCalendar.getColor()); values.put(Calendars.CALENDAR_ACCESS_LEVEL, remoteCalendar.getAccessLevel()); getContentResolver().update(Calendars.CONTENT_URI, values, Calendars.ACCOUNT_NAME + " = ? AND " + Calendars.ACCOUNT_TYPE + " = ?" + " AND " + Calendars.NAME + " = ?", new String[]{account.name, account.type, remoteCalendar.getName()}); } private void deleteLocalCalendar(Account account, CalDavCalendar localCalendar) { getContentResolver().delete(Calendars.CONTENT_URI, Calendars.ACCOUNT_NAME + " = ? AND " + Calendars.ACCOUNT_TYPE + " = ?" + " AND " + Calendars.NAME + " = ?", new String[]{account.name, account.type, localCalendar.getName()}); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后知晚觉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值