нет, но можно использовать вот это для написания функции:есть какой-то опкод, который записывает в переменную дамаг, который я кому-то нанёс
Компилирую код без изменения, всё отлично. Захожу в игру клео не работает. В theards, active = falseCLEO:{$CLEO} {$NOSOURCE} 0000: 8028: not $707 >= 16 jf @1 0A93: вырубить_скрипт :1 wait 0 0AFA: is_samp_available jf @1 0B34: samp register_client_command "Bullet" to_label @Bullet 0BDE: pause_thread 0 :Bullet 0006: 0@ = -1 :BulletMainLoop 0@ += 1 not 0@ == 1001 jf @BulletExitLoop if and 0B23: samp is_player_connected 0@ 8B5C: not samp is_player 0@ paused 8B64: not samp is_player 0@ npc jf @BulletMainLoop 0B20: samp 1@ = actor_handle_by_samp_player_id 0@ 056D: actor 1@ defined jf @BulletMainLoop 00A0: store_actor 1@ position_to 2@ 3@ 4@ 00A0: store_actor $PLAYER_ACTOR position_to 5@ 6@ 7@ 0470: 8@ = actor $PLAYER_ACTOR current_weapon 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ jump @BulletMainLoop :BulletExitLoop 0B43: samp cmd_ret :BulletSync // 0AB1: call_scm_func @BulletSync 12 byteType 1 sTargetID 0@ fOrigin 5@ 6@ 7@ fTarget 2@ 3@ 4@ fCenter 0.0 0.0 0.5 byteWeaponID 8@ 0AC8: 25@ = allocate_memory_size 40 // sizeof_stBulletData 0C0D: struct 25@ offset 0 size 1 = 0@ // uint8_t byteType; 0C0D: struct 25@ offset 1 size 2 = 1@ // uint16_t sTargetID; 0C0D: struct 25@ offset 3 size 4 = 2@ // float fOrigin[3]; 0C0D: struct 25@ offset 7 size 4 = 3@ // float fOrigin[3]; 0C0D: struct 25@ offset 11 size 4 = 4@ // float fOrigin[3]; 0C0D: struct 25@ offset 15 size 4 = 5@ // float fTarget[3]; 0C0D: struct 25@ offset 19 size 4 = 6@ // float fTarget[3]; 0C0D: struct 25@ offset 23 size 4 = 7@ // float fTarget[3]; 0C0D: struct 25@ offset 27 size 4 = 8@ // float fCenter[3]; 0C0D: struct 25@ offset 31 size 4 = 9@ // float fCenter[3]; 0C0D: struct 25@ offset 35 size 4 = 10@ // float fCenter[3]; 0C0D: struct 25@ offset 39 size 1 = 11@ // uint8_t byteWeaponID; 0BC4: samp send_bullet_data 25@ 0AC9: free_allocated_memory 25@ 0AB2: ret 0
Вроде етоКак сделать проверку что деалог открыт?
Как сделать проверку что деалог открыт?
0B4E: samp 0@ = get_current_dialog_id // получаешь ид текущего/последнего диалога
0B4C: samp is_dialog_active 0@ // проверяешь, активен ли текущий/последний диалог
{$CLEO}
0000: NOP
repeat
wait 8000
until 0AFA: is_samp_available
while true
wait 0
if and
8B21: samp chat_is_not_opened
0ADC: test_cheat "123"
then
alloc 0@ 64
format 0@ "1%c2%c3%c4%c" 0xA 0xA 0xA
0B3B: samp show_dialog id 47 caption "123" text 0@ button_1 "Âûáðàòü" button_2 "Îòìåíà" style 2
free 0@
end
if 0B3C: samp is_dialog_responded id 47 button 3@ list_item 4@ input_text 0
then
if 3@ == 1
then
018C: play_sound 1058 at 0.0 0.0 0.0
if 4@ == 0
then
end
if 4@ == 1
then
end
if 4@ == 2
then
end
if 4@ == 3
then
end
end
end
где я включил ашота?
{$CLEO}
0000: NOP
repeat
wait 40
until 0AFA: is_samp_available
while true
:loop
wait 0
if and
8B21: not samp chat_is_not_opened
0ADC: test_cheat "123"
then
format 0@v "1%c2%c3%c4" 0xA 0xA 0xA
0B3B: samp show_dialog id 47 caption "123" text 0@v button_1 "Выбрать" button_2 "Отмена" style 2
end
if 0B3C: samp is_dialog_responded id 47 button 0@ list_item 1@ input_text 0
then
if 8039: not 0@ == 1
then
continue
end
018C: play_sound 1058 at 0.0 0.0 0.0
0012: 1@ *= 4
0AC6: 0@ = label @_jump_table_ offset
005A: 0@ += 1@
0A8D: 1@ = read_memory 0@ size 4 virtual_protect 0
gosub 1@
jump @loop
:_jump_table_
hex
@_choise_1_
@_choise_2_
@_choise_3_
@_choise_4_
end
:_choise_1_
0af8: "The first item has been selected" 0xFF0000
return
:_choise_2_
0af8: "The second item has been selected" 0x00FF00
return
:_choise_3_
0af8: "The third item has been selected" 0x0000FF
return
:_choise_4_
0af8: "The fourth item has been selected" 0xFFFFFF
return
end
end
Нет, это чисто серверная фича.Есть ли возможность реализовать перемещение в другой виртуальный мир с любого места? Если да, то как реализовать?
Нет, это чисто серверная фича.