OpenHarmony: text edit

This commit is contained in:
Coder2 2026-03-18 21:44:05 +08:00
parent 53423ec173
commit 274b90f7e5
No known key found for this signature in database
GPG key ID: 98C112D1F699AA4C
4 changed files with 11 additions and 61 deletions

View file

@ -16,6 +16,6 @@ include_directories(${NATIVERENDER_ROOT_PATH}
${NATIVERENDER_ROOT_PATH}/include
${SDL3_SOURCE_DIR}/include)
add_library(entry SHARED napi_init.cpp)
add_library(entry SHARED entrypoint.cpp)
add_dependencies(entry SDL3::SDL3-shared)
target_link_libraries(entry PUBLIC libace_napi.z.so libSDL3.so libvulkan.so libGLESv2.so libohaudio.so libohsensor.so)

View file

@ -8,7 +8,6 @@
#include "SDL3/SDL_vulkan.h"
#include "SDL3/SDL_locale.h"
#include "SDL3/SDL_clipboard.h"
#include "napi/native_api.h"
#include "SDL3/SDL_log.h"
#include "SDL3/SDL_hints.h"
#include "SDL3/SDL_power.h"
@ -23,44 +22,6 @@
#include <ohaudio/native_audiostreambuilder.h>
#include <fstream>
static napi_value Add(napi_env env, napi_callback_info info)
{
size_t argc = 2;
napi_value args[2] = {nullptr};
napi_get_cb_info(env, info, &argc, args , nullptr, nullptr);
napi_valuetype valuetype0;
napi_typeof(env, args[0], &valuetype0);
napi_valuetype valuetype1;
napi_typeof(env, args[1], &valuetype1);
double value0;
napi_get_value_double(env, args[0], &value0);
double value1;
napi_get_value_double(env, args[1], &value1);
napi_value sum;
napi_create_double(env, value0 + value1, &sum);
SDL_Log("Add invoke!");
return sum;
}
EXTERN_C_START
static napi_value Init(napi_env env, napi_value exports)
{
napi_property_descriptor desc[] = {
{ "add", nullptr, Add, nullptr, nullptr, nullptr, napi_default, nullptr }
};
napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
return exports;
}
float vtxdata[] = {
-0.5f, -0.5f, 0.f,
0.5f, -0.5f, 0.0f,
@ -124,8 +85,6 @@ int main()
SDL_Window* win = SDL_CreateWindow("test", 1024, 1024, SDL_WINDOW_OPENGL);
SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_INFORMATION, "SDL Application", "test!", win);
SDL_StartTextInput(win);
// SDL_StopTextInput();
auto context = SDL_GL_CreateContext(win);
SDL_GL_MakeCurrent(win, context);
@ -167,6 +126,7 @@ int main()
((PFNGLCLEARCOLORPROC)SDL_GL_GetProcAddress("glClearColor"))(0, 0, 0, 0);
while (true) {
SDL_StartTextInput(win);
int w, h;
SDL_GetWindowSize(win, &w, &h);
@ -200,6 +160,10 @@ int main()
if (event.type == SDL_EVENT_QUIT) {
break;
}
if (event.type == SDL_EVENT_TEXT_INPUT) {
SDL_Log("text %s", event.text.text);
}
}
}
@ -210,20 +174,4 @@ int main()
SDL_DestroyWindow(win);
return 0;
}
EXTERN_C_END
static napi_module demoModule = {
.nm_version = 1,
.nm_flags = 0,
.nm_filename = nullptr,
.nm_register_func = Init,
.nm_modname = "entry",
.nm_priv = ((void*)0),
.reserved = { 0 },
};
extern "C" __attribute__((constructor)) void RegisterEntryModule(void)
{
napi_module_register(&demoModule);
}
}

View file

@ -186,7 +186,6 @@ struct Index {
if (targetText.length > 0) {
targetText = targetText.substring(0, targetText.length - i)
}
hilog.info(DOMAIN, 'surfaceLayer', targetText)
})
controller.on('deleteRight', (i) => {
sdl.sdlTextEditing(targetText, 0, i);
@ -194,7 +193,6 @@ struct Index {
if (targetText.length > 0) {
targetText = targetText.substring(i, targetText.length)
}
hilog.info(DOMAIN, 'surfaceLayer', targetText)
})
}

View file

@ -800,6 +800,8 @@ static napi_value sdlTextAppend(napi_env env, napi_callback_info info)
SDL_SendKeyboardText(fname);
SDL_free(fname);
napi_value result;
napi_create_int32(env, 0, &result);
return result;
@ -822,6 +824,8 @@ static napi_value sdlTextEditing(napi_env env, napi_callback_info info)
SDL_SendEditingText(fname, start, len);
SDL_free(fname);
napi_value result;
napi_create_int32(env, 0, &result);
return result;