Форум Flasher.ru

Форум Flasher.ru (http://www.flasher.ru/forum/index.php)
-   ActionScript 1.0/2.0 (http://www.flasher.ru/forum/forumdisplay.php?f=93)
-   -   flash<vars>exsel (http://www.flasher.ru/forum/showthread.php?t=119644)

oloks 26.12.2008 10:37

flash<vars>exsel
 
На листе exsel лежит flash-мувик.
Подскажите пожадуста как им обменятся переменными?

artem_fs 26.12.2008 11:45

excel? незнал что можно в него флэшку вставить. подозреваю что обменяться не получится.

alexcon314 26.12.2008 11:47

Варианты:
- ExternalInteface (круто)
- fscommand (из флэша вызываем функции оболочки, наооборот нельзя)
- SetVariable/GetVariable(устарело. но самое простое)
Общий подход:
Размещаем флэш-контрол (ActiveX) на листе.
Кликаем два раза по нему. Откроется редактор VBA.
В редакторе видим окно с кодом для этого контрола.
В ObjectBrowser редактора находим поиском ShockWaveFalsh и смотрим список
доступных свойств и методов данного объекта.
В редакторе кода пишем необходимый функционал.
В окне свойств контрола выбираем мувик, который будет загружен в плеер и режим его отображения.

При использовании ExternalInterface в обработчик события FlashCall будет из флэша направлена xml-строка вида
Код:

<invoke name="functionName" returntype="xml"><arguments><string>my_string</string><number>my_number</number></arguments></invoke>
Код:

// во флэше
ExternalInterface.call("functionName","my_string",my_number);

так что прежде чем вызвать funcName(my_string, my_number) уже в оболочке придется распарсить эту строку.
То же происходит и при использовании CallFunction (вызов функции во флэше из оболочки), только наоборот: вам придется аргументом CallFunction передать подобного же вида xml-строку.
Т.е. речь идет о сериализации/десериализации запросов. На стороне флэша сериализация/десериализация происходит автоматически.

При использовании обработчика FSCommand аргументами его будут имя вызываемой функции и строка с аргументами. Вернуть значение после выполнения функции во флэш нельзя.
Код:

fscommand("functionName","bla-bla, 45");
SetVariable/GetVariable проще. Но фо флэше нужно будет делать какую-то "следилку" за переменной, что бы отловить момент ее изменения и предпринять какие-то действия. Т.е. вызов этих методов просто читает/пишет переменные в мувике, при этом никак не оповещая плеер об этом.

Само-собой, в редакторе кода VBA на ряду с флэш-контролом вы можете использовать стандартные переменные, свойства, методы любых других VBA-объетов, того же экселя, и не только. Т.е. листы экселя со значениями их полей и таблиц будут так же доступны и вы сможете передать их во флэш, обработать там и вернуть обратно.

Mnilionic 26.12.2008 14:31

круто! надо запомнить :)

oloks 27.12.2008 13:45

Спасибо за косультацыю.
ExternalInterface - для меня слишком круто будет.
А с остальным у меня проблемы с синтаксисом:
Код flash:
fscommand("functionName","bla-bla, 45"); - тобиш
functionName = моя функция в VB?
bla-bla, 45 = параметры к ней?
Код VB:
Private Sub ShockwaveFlash1_FSCommand(ByVal command As String, ByVal args As String)

End Sub
А тут что-куда писать?
-------------------------------
SetVariable/GetVariable проще. - не плохо бы примерчик
что в VB
что во flash
именно синтаксис - а то редактор VB или ругается или не компилирует.
Спасибо за участие.

Ksunny 08.01.2009 23:13

простите, что тут не в тему...я совсем не знаю Excel, но очень надо как то вытащить флеш игру из xsl документа... это возможно на самом примитивном уровне... или где то почитать про это можно??? в поисковиках я так толком не нашла ничего(((
заранее спасибо!


Часовой пояс GMT +4, время: 05:07.

Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.