spatial_editor_plugin.cpp 98 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647
  1. /*************************************************************************/
  2. /* spatial_editor_plugin.cpp */
  3. /*************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* http://www.godotengine.org */
  7. /*************************************************************************/
  8. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  9. /* */
  10. /* Permission is hereby granted, free of charge, to any person obtaining */
  11. /* a copy of this software and associated documentation files (the */
  12. /* "Software"), to deal in the Software without restriction, including */
  13. /* without limitation the rights to use, copy, modify, merge, publish, */
  14. /* distribute, sublicense, and/or sell copies of the Software, and to */
  15. /* permit persons to whom the Software is furnished to do so, subject to */
  16. /* the following conditions: */
  17. /* */
  18. /* The above copyright notice and this permission notice shall be */
  19. /* included in all copies or substantial portions of the Software. */
  20. /* */
  21. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  22. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  23. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
  24. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  25. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  26. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  27. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  28. /*************************************************************************/
  29. #include "spatial_editor_plugin.h"
  30. #include "print_string.h"
  31. #include "os/keyboard.h"
  32. #include "scene/3d/visual_instance.h"
  33. #include "scene/3d/camera.h"
  34. #include "camera_matrix.h"
  35. #include "sort.h"
  36. #include "tools/editor/editor_node.h"
  37. #include "tools/editor/editor_settings.h"
  38. #include "scene/resources/surface_tool.h"
  39. #include "tools/editor/spatial_editor_gizmos.h"
  40. #include "globals.h"
  41. #define DISTANCE_DEFAULT 4
  42. #define GIZMO_ARROW_SIZE 0.3
  43. #define GIZMO_RING_HALF_WIDTH 0.1
  44. //#define GIZMO_SCALE_DEFAULT 0.28
  45. #define GIZMO_SCALE_DEFAULT 0.15
  46. //void SpatialEditorViewport::_update_camera();
  47. String SpatialEditorGizmo::get_handle_name(int p_idx) const {
  48. return "";
  49. }
  50. Variant SpatialEditorGizmo::get_handle_value(int p_idx) const{
  51. return Variant();
  52. }
  53. void SpatialEditorGizmo::set_handle(int p_idx,Camera *p_camera, const Point2& p_point) {
  54. }
  55. void SpatialEditorGizmo::commit_handle(int p_idx,const Variant& p_restore,bool p_cancel){
  56. }
  57. bool SpatialEditorGizmo::intersect_frustum(const Camera *p_camera,const Vector<Plane> &p_frustum) {
  58. return false;
  59. }
  60. bool SpatialEditorGizmo::intersect_ray(const Camera *p_camera, const Point2 &p_point, Vector3& r_pos, Vector3& r_normal,int *r_gizmo_handle,bool p_sec_first) {
  61. return false;
  62. }
  63. SpatialEditorGizmo::SpatialEditorGizmo(){
  64. selected=false;
  65. }
  66. int SpatialEditorViewport::get_selected_count() const {
  67. Map<Node*,Object*> &selection = editor_selection->get_selection();
  68. int count=0;
  69. for(Map<Node*,Object*>::Element *E=selection.front();E;E=E->next()) {
  70. Spatial *sp = E->key()->cast_to<Spatial>();
  71. if (!sp)
  72. continue;
  73. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  74. if (!se)
  75. continue;
  76. count++;
  77. }
  78. return count;
  79. }
  80. float SpatialEditorViewport::get_znear() const {
  81. float val = spatial_editor->get_znear();
  82. if (val<0.001)
  83. val=0.001;
  84. return val;
  85. }
  86. float SpatialEditorViewport::get_zfar() const{
  87. float val = spatial_editor->get_zfar();
  88. if (val<0.001)
  89. val=0.001;
  90. return val;
  91. }
  92. float SpatialEditorViewport::get_fov() const{
  93. float val = spatial_editor->get_fov();
  94. if (val<0.001)
  95. val=0.001;
  96. if (val>89)
  97. val=89;
  98. return val;
  99. }
  100. Transform SpatialEditorViewport::_get_camera_transform() const {
  101. return camera->get_global_transform();
  102. }
  103. Vector3 SpatialEditorViewport::_get_camera_pos() const {
  104. return _get_camera_transform().origin;
  105. }
  106. Point2 SpatialEditorViewport::_point_to_screen(const Vector3& p_point) {
  107. return camera->unproject_position(p_point);
  108. }
  109. Vector3 SpatialEditorViewport::_get_ray_pos(const Vector2& p_pos) const {
  110. return camera->project_ray_origin(p_pos);
  111. }
  112. Vector3 SpatialEditorViewport::_get_camera_normal() const {
  113. return -_get_camera_transform().basis.get_axis(2);
  114. }
  115. Vector3 SpatialEditorViewport::_get_ray(const Vector2& p_pos) {
  116. return camera->project_ray_normal(p_pos);
  117. }
  118. /*
  119. void SpatialEditorViewport::_clear_id(Spatial *p_node) {
  120. editor_selection->remove_node(p_node);
  121. }
  122. */
  123. void SpatialEditorViewport::_clear_selected() {
  124. editor_selection->clear();
  125. }
  126. void SpatialEditorViewport::_select_clicked(bool p_append,bool p_single) {
  127. if (!clicked)
  128. return;
  129. Object *obj = ObjectDB::get_instance(clicked);
  130. if (!obj)
  131. return;
  132. Spatial *sp = obj->cast_to<Spatial>();
  133. if (!sp)
  134. return;
  135. _select(sp, clicked_wants_append,true);
  136. }
  137. void SpatialEditorViewport::_select(Spatial *p_node, bool p_append,bool p_single) {
  138. if (!p_append) {
  139. // should not modify the selection..
  140. editor_selection->clear();
  141. editor_selection->add_node(p_node);
  142. } else {
  143. if (editor_selection->is_selected(p_node) && p_single) {
  144. //erase
  145. editor_selection->remove_node(p_node);
  146. } else {
  147. editor_selection->add_node(p_node);
  148. }
  149. }
  150. }
  151. struct _RayResult {
  152. Spatial* item;
  153. float depth;
  154. int handle;
  155. _FORCE_INLINE_ bool operator<(const _RayResult& p_rr) const { return depth<p_rr.depth; }
  156. };
  157. ObjectID SpatialEditorViewport::_select_ray(const Point2& p_pos, bool p_append,bool &r_includes_current,int *r_gizmo_handle,bool p_alt_select) {
  158. if (r_gizmo_handle)
  159. *r_gizmo_handle=-1;
  160. Vector3 ray=_get_ray(p_pos);
  161. Vector3 pos=_get_ray_pos(p_pos);
  162. Vector<RID> instances=VisualServer::get_singleton()->instances_cull_ray(pos,ray,get_scene()->get_root()->get_world()->get_scenario() );
  163. Set<Ref<SpatialEditorGizmo> > found_gizmos;
  164. //uint32_t closest=0;
  165. // float closest_dist=0;
  166. r_includes_current=false;
  167. List<_RayResult> results;
  168. Vector3 cn=_get_camera_normal();
  169. Plane cplane(pos,cn.normalized());
  170. float min_d=1e20;
  171. for (int i=0;i<instances.size();i++) {
  172. uint32_t id=VisualServer::get_singleton()->instance_get_object_instance_ID(instances[i]);
  173. Object *obj=ObjectDB::get_instance(id);
  174. if (!obj)
  175. continue;
  176. Spatial *spat=obj->cast_to<Spatial>();
  177. if (!spat)
  178. continue;
  179. Ref<SpatialEditorGizmo> seg = spat->get_gizmo();
  180. if (!seg.is_valid())
  181. continue;
  182. if (found_gizmos.has(seg))
  183. continue;
  184. found_gizmos.insert(seg);
  185. Vector3 point;
  186. Vector3 normal;
  187. int handle=-1;
  188. bool inters = seg->intersect_ray(camera,p_pos,point,normal,NULL,p_alt_select);
  189. if (!inters)
  190. continue;
  191. float dist = pos.distance_to(point);
  192. if (dist<0)
  193. continue;
  194. if (editor_selection->is_selected(spat))
  195. r_includes_current=true;
  196. _RayResult res;
  197. res.item=spat;
  198. res.depth=dist;
  199. res.handle=handle;
  200. results.push_back(res);
  201. }
  202. if (results.empty())
  203. return 0;
  204. results.sort();
  205. Spatial *s=NULL;
  206. if (!r_includes_current || results.size()==1 || (r_gizmo_handle && results.front()->get().handle>=0)) {
  207. //return the nearest one
  208. s = results.front()->get().item;
  209. if (r_gizmo_handle)
  210. *r_gizmo_handle=results.front()->get().handle;
  211. } else {
  212. //returns the next one from a curent selection
  213. List<_RayResult>::Element *E=results.front();
  214. List<_RayResult>::Element *S=NULL;
  215. while(true) {
  216. //very strange loop algorithm that complies with object selection standards (tm).
  217. if (S==E) {
  218. //went all around and anothing was found
  219. //since can't rotate the selection
  220. //just return the first one
  221. s=results.front()->get().item;
  222. break;
  223. }
  224. if (!S && editor_selection->is_selected(E->get().item)) {
  225. //found an item currently in the selection,
  226. //so start from this one
  227. S=E;
  228. }
  229. if (S && !editor_selection->is_selected(E->get().item)) {
  230. // free item after a selected item, this one is desired.
  231. s=E->get().item;
  232. break;
  233. }
  234. E=E->next();
  235. if (!E) {
  236. if (!S) {
  237. //did a loop but nothing was selected, select first
  238. s=results.front()->get().item;
  239. break;
  240. }
  241. E=results.front();
  242. }
  243. }
  244. }
  245. if (!s)
  246. return 0;
  247. return s->get_instance_ID();
  248. }
  249. Vector3 SpatialEditorViewport::_get_screen_to_space(const Vector3& p_pos) {
  250. CameraMatrix cm;
  251. cm.set_perspective(get_fov(),get_size().get_aspect(),get_znear(),get_zfar());
  252. float screen_w,screen_h;
  253. cm.get_viewport_size(screen_w,screen_h);
  254. Transform camera_transform;
  255. camera_transform.translate( cursor.pos );
  256. camera_transform.basis.rotate(Vector3(0,1,0),cursor.y_rot);
  257. camera_transform.basis.rotate(Vector3(1,0,0),cursor.x_rot);
  258. camera_transform.translate(0,0,cursor.distance);
  259. return camera_transform.xform(Vector3( ((p_pos.x/get_size().width)*2.0-1.0)*screen_w, ((1.0-(p_pos.y/get_size().height))*2.0-1.0)*screen_h,-get_znear()));
  260. }
  261. void SpatialEditorViewport::_select_region() {
  262. if (cursor.region_begin==cursor.region_end)
  263. return; //nothing really
  264. Vector3 box[4]={
  265. Vector3(
  266. MIN( cursor.region_begin.x, cursor.region_end.x),
  267. MIN( cursor.region_begin.y, cursor.region_end.y),
  268. 0
  269. ),
  270. Vector3(
  271. MAX( cursor.region_begin.x, cursor.region_end.x),
  272. MIN( cursor.region_begin.y, cursor.region_end.y),
  273. 0
  274. ),
  275. Vector3(
  276. MAX( cursor.region_begin.x, cursor.region_end.x),
  277. MAX( cursor.region_begin.y, cursor.region_end.y),
  278. 0
  279. ),
  280. Vector3(
  281. MIN( cursor.region_begin.x, cursor.region_end.x),
  282. MAX( cursor.region_begin.y, cursor.region_end.y),
  283. 0
  284. )
  285. };
  286. Vector<Plane> frustum;
  287. Vector3 cam_pos=_get_camera_pos();
  288. Set<Ref<SpatialEditorGizmo> > found_gizmos;
  289. for(int i=0;i<4;i++) {
  290. Vector3 a=_get_screen_to_space(box[i]);
  291. Vector3 b=_get_screen_to_space(box[(i+1)%4]);
  292. frustum.push_back( Plane(a,b,cam_pos) );
  293. }
  294. Plane near( cam_pos, -_get_camera_normal() );
  295. near.d-=get_znear();
  296. frustum.push_back( near );
  297. Plane far=-near;
  298. far.d+=500.0;
  299. frustum.push_back( far );
  300. Vector<RID> instances=VisualServer::get_singleton()->instances_cull_convex(frustum,get_scene()->get_root()->get_world()->get_scenario());
  301. for (int i=0;i<instances.size();i++) {
  302. uint32_t id=VisualServer::get_singleton()->instance_get_object_instance_ID(instances[i]);
  303. Object *obj=ObjectDB::get_instance(id);
  304. if (!obj)
  305. continue;
  306. Spatial *sp = obj->cast_to<Spatial>();
  307. if (!sp)
  308. continue;
  309. Ref<SpatialEditorGizmo> seg = sp->get_gizmo();
  310. if (!seg.is_valid())
  311. continue;
  312. if (found_gizmos.has(seg))
  313. continue;
  314. if (seg->intersect_frustum(camera,frustum))
  315. _select(sp,true,false);
  316. }
  317. }
  318. void SpatialEditorViewport::_compute_edit(const Point2& p_point) {
  319. _edit.click_ray=_get_ray( Vector2( p_point.x, p_point.y ) );
  320. _edit.click_ray_pos=_get_ray_pos( Vector2( p_point.x, p_point.y ) );
  321. _edit.plane=TRANSFORM_VIEW;
  322. spatial_editor->update_transform_gizmo();
  323. _edit.center=spatial_editor->get_gizmo_transform().origin;
  324. List<Node*> &selection = editor_selection->get_selected_node_list();
  325. // Vector3 center;
  326. // int nc=0;
  327. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  328. Spatial *sp = E->get()->cast_to<Spatial>();
  329. if (!sp)
  330. continue;
  331. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  332. if (!se)
  333. continue;
  334. se->original=se->sp->get_global_transform();
  335. // center+=se->original.origin;
  336. // nc++;
  337. }
  338. // if (nc)
  339. // _edit.center=center/float(nc);
  340. }
  341. static int _get_key_modifier(const String& p_property) {
  342. switch(EditorSettings::get_singleton()->get(p_property).operator int()) {
  343. case 0: return 0;
  344. case 1: return KEY_SHIFT;
  345. case 2: return KEY_ALT;
  346. case 3: return KEY_META;
  347. case 4: return KEY_CONTROL;
  348. }
  349. return 0;
  350. }
  351. SpatialEditorViewport::NavigationScheme SpatialEditorViewport::_get_navigation_schema(const String& p_property) {
  352. switch(EditorSettings::get_singleton()->get(p_property).operator int()) {
  353. case 0: return NAVIGATION_GODOT;
  354. case 1: return NAVIGATION_MAYA;
  355. case 2: return NAVIGATION_MODO;
  356. }
  357. return NAVIGATION_GODOT;
  358. }
  359. bool SpatialEditorViewport::_gizmo_select(const Vector2& p_screenpos,bool p_hilite_only) {
  360. if (!spatial_editor->is_gizmo_visible())
  361. return false;
  362. if (get_selected_count()==0) {
  363. if (p_hilite_only)
  364. spatial_editor->select_gizmo_hilight_axis(-1);
  365. return false;
  366. }
  367. Vector3 ray_pos=_get_ray_pos( Vector2( p_screenpos.x, p_screenpos.y ) );
  368. Vector3 ray=_get_ray( Vector2( p_screenpos.x, p_screenpos.y ) );
  369. Vector3 cn=_get_camera_normal();
  370. Plane cplane(ray_pos,cn.normalized());
  371. Transform gt = spatial_editor->get_gizmo_transform();
  372. float gs=gizmo_scale;
  373. /*
  374. if (orthogonal) {
  375. gs= cursor.distance/surface->get_size().get_aspect();
  376. } else {
  377. gs = cplane.distance_to(gt.origin);
  378. }
  379. gs*=GIZMO_SCALE_DEFAULT;
  380. */
  381. if (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_MOVE) {
  382. int col_axis=-1;
  383. float col_d=1e20;
  384. for(int i=0;i<3;i++) {
  385. Vector3 grabber_pos = gt.origin+gt.basis.get_axis(i)*gs;
  386. float grabber_radius = gs*GIZMO_ARROW_SIZE;
  387. Vector3 r;
  388. if (Geometry::segment_intersects_sphere(ray_pos,ray_pos+ray*10000.0,grabber_pos,grabber_radius,&r)) {
  389. float d = r.distance_to(ray_pos);
  390. if (d<col_d) {
  391. col_d=d;
  392. col_axis=i;
  393. }
  394. }
  395. }
  396. if (col_axis!=-1) {
  397. if (p_hilite_only) {
  398. spatial_editor->select_gizmo_hilight_axis(col_axis);
  399. } else {
  400. //handle rotate
  401. _edit.mode=TRANSFORM_TRANSLATE;
  402. _compute_edit(Point2(p_screenpos.x,p_screenpos.y));
  403. _edit.plane=TransformPlane(TRANSFORM_X_AXIS+col_axis);
  404. }
  405. return true;
  406. }
  407. }
  408. if (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_ROTATE) {
  409. int col_axis=-1;
  410. float col_d=1e20;
  411. for(int i=0;i<3;i++) {
  412. Plane plane(gt.origin,gt.basis.get_axis(i).normalized());
  413. Vector3 r;
  414. if (!plane.intersects_ray(ray_pos,ray,&r))
  415. continue;
  416. float dist = r.distance_to(gt.origin);
  417. if (dist > gs*(1-GIZMO_RING_HALF_WIDTH) && dist < gs *(1+GIZMO_RING_HALF_WIDTH)) {
  418. float d = ray_pos.distance_to(r);
  419. if (d<col_d) {
  420. col_d=d;
  421. col_axis=i;
  422. }
  423. }
  424. }
  425. if (col_axis!=-1) {
  426. if (p_hilite_only) {
  427. spatial_editor->select_gizmo_hilight_axis(col_axis+3);
  428. } else {
  429. //handle rotate
  430. _edit.mode=TRANSFORM_ROTATE;
  431. _compute_edit(Point2(p_screenpos.x,p_screenpos.y));
  432. _edit.plane=TransformPlane(TRANSFORM_X_AXIS+col_axis);
  433. }
  434. return true;
  435. }
  436. }
  437. if (p_hilite_only)
  438. spatial_editor->select_gizmo_hilight_axis(-1);
  439. return false;
  440. }
  441. void SpatialEditorViewport::_smouseenter() {
  442. surface->grab_focus();
  443. }
  444. void SpatialEditorViewport::_sinput(const InputEvent &p_event) {
  445. if (previewing)
  446. return; //do NONE
  447. {
  448. EditorNode *en = editor;
  449. EditorPlugin *over_plugin = en->get_editor_plugin_over();
  450. if (over_plugin) {
  451. bool discard = over_plugin->forward_spatial_input_event(camera,p_event);
  452. if (discard)
  453. return;
  454. }
  455. }
  456. switch(p_event.type) {
  457. case InputEvent::MOUSE_BUTTON: {
  458. const InputEventMouseButton &b=p_event.mouse_button;
  459. switch(b.button_index) {
  460. case BUTTON_WHEEL_UP: {
  461. cursor.distance/=1.08;
  462. if (cursor.distance<0.001)
  463. cursor.distance=0.001;
  464. } break;
  465. case BUTTON_WHEEL_DOWN: {
  466. if (cursor.distance<0.001)
  467. cursor.distance=0.001;
  468. cursor.distance*=1.08;
  469. } break;
  470. case BUTTON_RIGHT: {
  471. if (b.pressed && _edit.gizmo.is_valid()) {
  472. //restore
  473. _edit.gizmo->commit_handle(_edit.gizmo_handle,_edit.gizmo_initial_value,true);
  474. _edit.gizmo=Ref<SpatialEditorGizmo>();
  475. }
  476. if (_edit.mode==TRANSFORM_NONE && b.pressed) {
  477. Plane cursor_plane(cursor.cursor_pos,_get_camera_normal());
  478. Vector3 ray_origin = _get_ray_pos(Vector2(b.x,b.y));
  479. Vector3 ray_dir = _get_ray(Vector2(b.x,b.y));
  480. //gizmo modify
  481. if (b.mod.control) {
  482. Vector<RID> instances=VisualServer::get_singleton()->instances_cull_ray(ray_origin,ray_dir,get_scene()->get_root()->get_world()->get_scenario() );
  483. Plane p(ray_origin,_get_camera_normal());
  484. float min_d=1e10;
  485. bool found=false;
  486. for (int i=0;i<instances.size();i++) {
  487. uint32_t id=VisualServer::get_singleton()->instance_get_object_instance_ID(instances[i]);
  488. Object *obj=ObjectDB::get_instance(id);
  489. if (!obj)
  490. continue;
  491. VisualInstance *vi=obj->cast_to<VisualInstance>();
  492. if (!vi)
  493. continue;
  494. //optimize by checking AABB (although should pre sort by distance)
  495. AABB aabb = vi->get_global_transform().xform(vi->get_aabb());
  496. if (p.distance_to(aabb.get_support(-ray_dir))>min_d)
  497. continue;
  498. DVector<Face3> faces = vi->get_faces(VisualInstance::FACES_SOLID);
  499. int c = faces.size();
  500. if (c>0) {
  501. DVector<Face3>::Read r = faces.read();
  502. for(int j=0;j<c;j++) {
  503. Vector3 inters;
  504. if (r[j].intersects_ray(ray_origin,ray_dir,&inters)) {
  505. float d = p.distance_to(inters);
  506. if (d<0)
  507. continue;
  508. if (d<min_d) {
  509. min_d=d;
  510. found=true;
  511. }
  512. }
  513. }
  514. }
  515. }
  516. if (found) {
  517. //cursor.cursor_pos=ray_origin+ray_dir*min_d;
  518. //VisualServer::get_singleton()->instance_set_transform(cursor_instance,Transform(Matrix3(),cursor.cursor_pos));
  519. }
  520. } else {
  521. Vector3 new_pos;
  522. if (cursor_plane.intersects_ray(ray_origin,ray_dir,&new_pos)) {
  523. //cursor.cursor_pos=new_pos;
  524. //VisualServer::get_singleton()->instance_set_transform(cursor_instance,Transform(Matrix3(),cursor.cursor_pos));
  525. }
  526. }
  527. }
  528. if (_edit.mode!=TRANSFORM_NONE && b.pressed) {
  529. //cancel motion
  530. _edit.mode=TRANSFORM_NONE;
  531. //_validate_selection();
  532. List<Node*> &selection = editor_selection->get_selected_node_list();
  533. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  534. Spatial *sp = E->get()->cast_to<Spatial>();
  535. if (!sp)
  536. continue;
  537. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  538. if (!se)
  539. continue;
  540. sp->set_global_transform( se->original );
  541. }
  542. surface->update();
  543. //VisualServer::get_singleton()->poly_clear(indicators);
  544. set_message("Transform Aborted.",3);
  545. }
  546. } break;
  547. case BUTTON_MIDDLE: {
  548. if (b.pressed && _edit.mode!=TRANSFORM_NONE) {
  549. switch(_edit.plane ) {
  550. case TRANSFORM_VIEW: {
  551. _edit.plane=TRANSFORM_X_AXIS;
  552. set_message("View Plane Transform.",2);
  553. } break;
  554. case TRANSFORM_X_AXIS: {
  555. _edit.plane=TRANSFORM_Y_AXIS;
  556. set_message("X-Axis Transform.",2);
  557. } break;
  558. case TRANSFORM_Y_AXIS: {
  559. _edit.plane=TRANSFORM_Z_AXIS;
  560. set_message("Y-Axis Transform.",2);
  561. } break;
  562. case TRANSFORM_Z_AXIS: {
  563. _edit.plane=TRANSFORM_VIEW;
  564. set_message("Z-Axis Transform.",2);
  565. } break;
  566. }
  567. }
  568. } break;
  569. case BUTTON_LEFT: {
  570. if (b.pressed) {
  571. NavigationScheme nav_scheme = _get_navigation_schema("3d_editor/navigation_scheme");
  572. if ( (nav_scheme==NAVIGATION_MAYA || nav_scheme==NAVIGATION_MODO) && b.mod.alt) {
  573. break;
  574. }
  575. _edit.mouse_pos=Point2(b.x,b.y);
  576. _edit.snap=false;
  577. _edit.mode=TRANSFORM_NONE;
  578. //gizmo has priority over everything
  579. if (spatial_editor->get_selected()) {
  580. Ref<SpatialEditorGizmo> seg = spatial_editor->get_selected()->get_gizmo();
  581. if (seg.is_valid()) {
  582. int handle=-1;
  583. Vector3 point;
  584. Vector3 normal;
  585. bool inters = seg->intersect_ray(camera,_edit.mouse_pos,point,normal,&handle,b.mod.shift);
  586. if (inters && handle!=-1) {
  587. _edit.gizmo=seg;
  588. _edit.gizmo_handle=handle;
  589. //_edit.gizmo_initial_pos=seg->get_handle_pos(gizmo_handle);
  590. _edit.gizmo_initial_value=seg->get_handle_value(handle);
  591. break;
  592. }
  593. }
  594. }
  595. if (_gizmo_select(_edit.mouse_pos))
  596. break;
  597. clicked=0;
  598. clicked_includes_current=false;
  599. if ((spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SELECT && b.mod.control) || spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_ROTATE) {
  600. /* HANDLE ROTATION */
  601. if (get_selected_count()==0)
  602. break; //bye
  603. //handle rotate
  604. _edit.mode=TRANSFORM_ROTATE;
  605. _compute_edit(Point2(b.x,b.y));
  606. break;
  607. }
  608. if (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_MOVE) {
  609. if (get_selected_count()==0)
  610. break; //bye
  611. //handle rotate
  612. _edit.mode=TRANSFORM_TRANSLATE;
  613. _compute_edit(Point2(b.x,b.y));
  614. break;
  615. }
  616. if (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SCALE) {
  617. if (get_selected_count()==0)
  618. break; //bye
  619. //handle rotate
  620. _edit.mode=TRANSFORM_SCALE;
  621. _compute_edit(Point2(b.x,b.y));
  622. break;
  623. }
  624. // todo scale
  625. int gizmo_handle=-1;
  626. clicked=_select_ray(Vector2( b.x, b.y ),b.mod.shift,clicked_includes_current,&gizmo_handle,b.mod.shift);
  627. //clicking is always deferred to either move or release
  628. clicked_wants_append=b.mod.shift;
  629. if (!clicked) {
  630. if (!clicked_wants_append)
  631. _clear_selected();
  632. //default to regionselect
  633. cursor.region_select=true;
  634. cursor.region_begin=Point2(b.x,b.y);
  635. cursor.region_end=Point2(b.x,b.y);
  636. }
  637. if (clicked && gizmo_handle>=0) {
  638. Object *obj=ObjectDB::get_instance(clicked);
  639. if (obj) {
  640. Spatial *spa = obj->cast_to<Spatial>();
  641. if (spa) {
  642. Ref<SpatialEditorGizmo> seg=spa->get_gizmo();
  643. if (seg.is_valid()) {
  644. _edit.gizmo=seg;
  645. _edit.gizmo_handle=gizmo_handle;
  646. //_edit.gizmo_initial_pos=seg->get_handle_pos(gizmo_handle);
  647. _edit.gizmo_initial_value=seg->get_handle_value(gizmo_handle);
  648. //print_line("GIZMO: "+itos(gizmo_handle)+" FROMPOS: "+_edit.orig_gizmo_pos);
  649. break;
  650. }
  651. }
  652. }
  653. //_compute_edit(Point2(b.x,b.y)); //in case a motion happens..
  654. }
  655. surface->update();
  656. } else {
  657. if (_edit.gizmo.is_valid()) {
  658. _edit.gizmo->commit_handle(_edit.gizmo_handle,_edit.gizmo_initial_value,false);
  659. _edit.gizmo=Ref<SpatialEditorGizmo>();
  660. break;
  661. }
  662. if (clicked) {
  663. _select_clicked(clicked_wants_append,true);
  664. //clickd processing was deferred
  665. clicked=0;
  666. }
  667. if (cursor.region_select) {
  668. _select_region();
  669. cursor.region_select=false;
  670. surface->update();
  671. }
  672. if (_edit.mode!=TRANSFORM_NONE) {
  673. static const char* _transform_name[4]={"None","Rotate","Translate","Scale"};
  674. undo_redo->create_action(_transform_name[_edit.mode]);
  675. List<Node*> &selection = editor_selection->get_selected_node_list();
  676. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  677. Spatial *sp = E->get()->cast_to<Spatial>();
  678. if (!sp)
  679. continue;
  680. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  681. if (!se)
  682. continue;
  683. undo_redo->add_do_method(sp,"set_global_transform",sp->get_global_transform());
  684. undo_redo->add_undo_method(sp,"set_global_transform",se->original);
  685. }
  686. undo_redo->commit_action();
  687. _edit.mode=TRANSFORM_NONE;
  688. //VisualServer::get_singleton()->poly_clear(indicators);
  689. set_message("");
  690. }
  691. surface->update();
  692. }
  693. } break;
  694. }
  695. } break;
  696. case InputEvent::MOUSE_MOTION: {
  697. const InputEventMouseMotion &m=p_event.mouse_motion;
  698. _edit.mouse_pos=Point2(p_event.mouse_motion.x,p_event.mouse_motion.y);
  699. if (spatial_editor->get_selected()) {
  700. Ref<SpatialEditorGizmo> seg = spatial_editor->get_selected()->get_gizmo();
  701. if (seg.is_valid()) {
  702. int selected_handle=-1;
  703. int handle=-1;
  704. Vector3 point;
  705. Vector3 normal;
  706. bool inters = seg->intersect_ray(camera,_edit.mouse_pos,point,normal,&handle,false);
  707. if (inters && handle!=-1) {
  708. selected_handle=handle;
  709. }
  710. if (selected_handle!=spatial_editor->get_over_gizmo_handle()) {
  711. spatial_editor->set_over_gizmo_handle(selected_handle);
  712. spatial_editor->get_selected()->update_gizmo();
  713. if (selected_handle!=-1)
  714. spatial_editor->select_gizmo_hilight_axis(-1);
  715. }
  716. }
  717. }
  718. if (spatial_editor->get_over_gizmo_handle()==-1 && !(m.button_mask&1) && !_edit.gizmo.is_valid()) {
  719. _gizmo_select(_edit.mouse_pos,true);
  720. }
  721. NavigationScheme nav_scheme = _get_navigation_schema("3d_editor/navigation_scheme");
  722. NavigationMode nav_mode = NAVIGATION_NONE;
  723. if (_edit.gizmo.is_valid()) {
  724. Plane plane=Plane(_edit.gizmo_initial_pos,_get_camera_normal());
  725. Vector3 ray_pos=_get_ray_pos( Vector2( m.x, m.y ) );
  726. Vector3 ray=_get_ray( Vector2( m.x, m.y ) );
  727. //Vector3 intersection;
  728. //if (!plane.intersects_ray(ray_pos,ray,&intersection))
  729. // break;
  730. _edit.gizmo->set_handle(_edit.gizmo_handle,camera,Vector2(m.x,m.y));
  731. Variant v = _edit.gizmo->get_handle_value(_edit.gizmo_handle);
  732. String n = _edit.gizmo->get_handle_name(_edit.gizmo_handle);
  733. set_message(n+": "+String(v));
  734. } else if (m.button_mask&1) {
  735. if (nav_scheme == NAVIGATION_MAYA && m.mod.alt) {
  736. nav_mode = NAVIGATION_ORBIT;
  737. } else if (nav_scheme == NAVIGATION_MODO && m.mod.alt && m.mod.shift) {
  738. nav_mode = NAVIGATION_PAN;
  739. } else if (nav_scheme == NAVIGATION_MODO && m.mod.alt && m.mod.control) {
  740. nav_mode = NAVIGATION_ZOOM;
  741. } else if (nav_scheme == NAVIGATION_MODO && m.mod.alt) {
  742. nav_mode = NAVIGATION_ORBIT;
  743. } else {
  744. if (clicked) {
  745. if (!clicked_includes_current) {
  746. _select_clicked(clicked_wants_append,true);
  747. //clickd processing was deferred
  748. }
  749. _compute_edit(_edit.mouse_pos);
  750. clicked=0;
  751. _edit.mode=TRANSFORM_TRANSLATE;
  752. }
  753. if (cursor.region_select && nav_mode == NAVIGATION_NONE) {
  754. cursor.region_end=Point2(m.x,m.y);
  755. surface->update();
  756. return;
  757. }
  758. if (_edit.mode==TRANSFORM_NONE && nav_mode == NAVIGATION_NONE)
  759. break;
  760. Vector3 ray_pos=_get_ray_pos( Vector2( m.x, m.y ) );
  761. Vector3 ray=_get_ray( Vector2( m.x, m.y ) );
  762. switch(_edit.mode) {
  763. case TRANSFORM_SCALE: {
  764. Plane plane=Plane(_edit.center,_get_camera_normal());
  765. Vector3 intersection;
  766. if (!plane.intersects_ray(ray_pos,ray,&intersection))
  767. break;
  768. Vector3 click;
  769. if (!plane.intersects_ray(_edit.click_ray_pos,_edit.click_ray,&click))
  770. break;
  771. float center_click_dist = click.distance_to(_edit.center);
  772. float center_inters_dist = intersection.distance_to(_edit.center);
  773. if (center_click_dist==0)
  774. break;
  775. float scale = (center_inters_dist / center_click_dist)*100.0;
  776. if (_edit.snap || spatial_editor->is_snap_enabled()) {
  777. scale = Math::stepify(scale,spatial_editor->get_scale_snap());
  778. }
  779. set_message("Scaling to "+String::num(scale,1)+"%.");
  780. scale/=100.0;
  781. Transform r;
  782. r.basis.scale(Vector3(scale,scale,scale));
  783. List<Node*> &selection = editor_selection->get_selected_node_list();
  784. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  785. Spatial *sp = E->get()->cast_to<Spatial>();
  786. if (!sp)
  787. continue;
  788. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  789. if (!se)
  790. continue;
  791. Transform original=se->original;
  792. Transform base=Transform( Matrix3(), _edit.center);
  793. Transform t=base * (r * (base.inverse() * original));
  794. sp->set_global_transform(t);
  795. }
  796. surface->update();
  797. } break;
  798. case TRANSFORM_TRANSLATE: {
  799. Vector3 motion_mask;
  800. Plane plane;
  801. switch( _edit.plane ) {
  802. case TRANSFORM_VIEW:
  803. motion_mask=Vector3(0,0,0);
  804. plane=Plane(_edit.center,_get_camera_normal());
  805. break;
  806. case TRANSFORM_X_AXIS:
  807. motion_mask=spatial_editor->get_gizmo_transform().basis.get_axis(0);
  808. plane=Plane(_edit.center,motion_mask.cross(motion_mask.cross(_get_camera_normal())).normalized());
  809. break;
  810. case TRANSFORM_Y_AXIS:
  811. motion_mask=spatial_editor->get_gizmo_transform().basis.get_axis(1);
  812. plane=Plane(_edit.center,motion_mask.cross(motion_mask.cross(_get_camera_normal())).normalized());
  813. break;
  814. case TRANSFORM_Z_AXIS:
  815. motion_mask=spatial_editor->get_gizmo_transform().basis.get_axis(2);
  816. plane=Plane(_edit.center,motion_mask.cross(motion_mask.cross(_get_camera_normal())).normalized());
  817. break;
  818. }
  819. Vector3 intersection;
  820. if (!plane.intersects_ray(ray_pos,ray,&intersection))
  821. break;
  822. Vector3 click;
  823. if (!plane.intersects_ray(_edit.click_ray_pos,_edit.click_ray,&click))
  824. break;
  825. //_validate_selection();
  826. Vector3 motion = intersection-click;
  827. if (motion_mask!=Vector3()) {
  828. motion=motion_mask.dot(motion)*motion_mask;
  829. }
  830. float snap=0;
  831. if (_edit.snap || spatial_editor->is_snap_enabled()) {
  832. snap = spatial_editor->get_translate_snap();
  833. motion.snap(snap);
  834. }
  835. //set_message("Translating: "+motion);
  836. List<Node*> &selection = editor_selection->get_selected_node_list();
  837. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  838. Spatial *sp = E->get()->cast_to<Spatial>();
  839. if (!sp) {
  840. continue;
  841. }
  842. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  843. if (!se) {
  844. continue;
  845. }
  846. Transform t=se->original;
  847. t.origin+=motion;
  848. sp->set_global_transform(t);
  849. }
  850. } break;
  851. case TRANSFORM_ROTATE: {
  852. Plane plane;
  853. switch( _edit.plane ) {
  854. case TRANSFORM_VIEW:
  855. plane=Plane(_edit.center,_get_camera_normal());
  856. break;
  857. case TRANSFORM_X_AXIS:
  858. plane=Plane(_edit.center,spatial_editor->get_gizmo_transform().basis.get_axis(0));
  859. break;
  860. case TRANSFORM_Y_AXIS:
  861. plane=Plane(_edit.center,spatial_editor->get_gizmo_transform().basis.get_axis(1));
  862. break;
  863. case TRANSFORM_Z_AXIS:
  864. plane=Plane(_edit.center,spatial_editor->get_gizmo_transform().basis.get_axis(2));
  865. break;
  866. }
  867. Vector3 intersection;
  868. if (!plane.intersects_ray(ray_pos,ray,&intersection))
  869. break;
  870. Vector3 click;
  871. if (!plane.intersects_ray(_edit.click_ray_pos,_edit.click_ray,&click))
  872. break;
  873. Vector3 y_axis=(click-_edit.center).normalized();
  874. Vector3 x_axis=plane.normal.cross(y_axis).normalized();
  875. float angle=Math::atan2( x_axis.dot(intersection-_edit.center), y_axis.dot(intersection-_edit.center) );
  876. if (_edit.snap || spatial_editor->is_snap_enabled()) {
  877. float snap = spatial_editor->get_rotate_snap();
  878. if (snap) {
  879. angle=Math::rad2deg(angle)+snap*0.5; //else it wont reach +180
  880. angle-=Math::fmod(angle,snap);
  881. set_message("Rotating "+rtos(angle)+" degrees.");
  882. angle=Math::deg2rad(angle);
  883. } else
  884. set_message("Rotating "+rtos(Math::rad2deg(angle))+" degrees.");
  885. } else {
  886. set_message("Rotating "+rtos(Math::rad2deg(angle))+" degrees.");
  887. }
  888. Transform r;
  889. r.basis.rotate(plane.normal,-angle);
  890. List<Node*> &selection = editor_selection->get_selected_node_list();
  891. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  892. Spatial *sp = E->get()->cast_to<Spatial>();
  893. if (!sp)
  894. continue;
  895. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  896. if (!se)
  897. continue;
  898. Transform original=se->original;
  899. Transform base=Transform( Matrix3(), _edit.center);
  900. Transform t=base * (r * (base.inverse() * original));
  901. sp->set_global_transform(t);
  902. }
  903. surface->update();
  904. /*
  905. VisualServer::get_singleton()->poly_clear(indicators);
  906. Vector<Vector3> points;
  907. Vector<Vector3> empty;
  908. Vector<Color> colors;
  909. points.push_back(intersection);
  910. points.push_back(_edit.original.origin);
  911. colors.push_back( Color(255,155,100) );
  912. colors.push_back( Color(255,155,100) );
  913. VisualServer::get_singleton()->poly_add_primitive(indicators,points,empty,colors,empty);
  914. */
  915. } break;
  916. default:{}
  917. }
  918. }
  919. } else if (m.button_mask&2) {
  920. if (nav_scheme == NAVIGATION_MAYA && m.mod.alt) {
  921. nav_mode = NAVIGATION_ZOOM;
  922. }
  923. } else if (m.button_mask&4) {
  924. if (nav_scheme == NAVIGATION_GODOT) {
  925. int mod = 0;
  926. if (m.mod.shift)
  927. mod=KEY_SHIFT;
  928. if (m.mod.alt)
  929. mod=KEY_ALT;
  930. if (m.mod.control)
  931. mod=KEY_CONTROL;
  932. if (m.mod.meta)
  933. mod=KEY_META;
  934. if (mod == _get_key_modifier("3d_editor/pan_modifier"))
  935. nav_mode = NAVIGATION_PAN;
  936. else if (mod == _get_key_modifier("3d_editor/zoom_modifier"))
  937. nav_mode = NAVIGATION_ZOOM;
  938. else if (mod == _get_key_modifier("3d_editor/orbit_modifier"))
  939. nav_mode = NAVIGATION_ORBIT;
  940. } else if (nav_scheme == NAVIGATION_MAYA) {
  941. if (m.mod.alt)
  942. nav_mode = NAVIGATION_PAN;
  943. }
  944. }
  945. switch(nav_mode) {
  946. case NAVIGATION_PAN:{
  947. real_t pan_speed = 1/150.0;
  948. int pan_speed_modifier = 10;
  949. if (nav_scheme==NAVIGATION_MAYA && m.mod.shift)
  950. pan_speed *= pan_speed_modifier;
  951. Transform camera_transform;
  952. camera_transform.translate(cursor.pos);
  953. camera_transform.basis.rotate(Vector3(0,1,0),cursor.y_rot);
  954. camera_transform.basis.rotate(Vector3(1,0,0),cursor.x_rot);
  955. Vector3 translation(-m.relative_x*pan_speed,m.relative_y*pan_speed,0);
  956. translation*=cursor.distance/DISTANCE_DEFAULT;
  957. camera_transform.translate(translation);
  958. cursor.pos=camera_transform.origin;
  959. } break;
  960. case NAVIGATION_ZOOM: {
  961. real_t zoom_speed = 1/80.0;
  962. int zoom_speed_modifier = 10;
  963. if (nav_scheme==NAVIGATION_MAYA && m.mod.shift)
  964. zoom_speed *= zoom_speed_modifier;
  965. if ( m.relative_y > 0)
  966. cursor.distance*=1+m.relative_y*zoom_speed;
  967. else if (m.relative_y < 0)
  968. cursor.distance/=1-m.relative_y*zoom_speed;
  969. } break;
  970. case NAVIGATION_ORBIT: {
  971. cursor.x_rot+=m.relative_y/80.0;
  972. cursor.y_rot+=m.relative_x/80.0;
  973. if (cursor.x_rot>Math_PI/2.0)
  974. cursor.x_rot=Math_PI/2.0;
  975. if (cursor.x_rot<-Math_PI/2.0)
  976. cursor.x_rot=-Math_PI/2.0;
  977. } break;
  978. default: {}
  979. }
  980. } break;
  981. case InputEvent::KEY: {
  982. const InputEventKey &k = p_event.key;
  983. switch(k.scancode) {
  984. case KEY_S: {
  985. if (_edit.mode!=TRANSFORM_NONE) {
  986. _edit.snap=true;
  987. }
  988. } break;
  989. case KEY_KP_7: {
  990. cursor.y_rot=0;
  991. if (k.mod.shift) {
  992. cursor.x_rot=-Math_PI/2.0;
  993. set_message("Bottom View.",2);
  994. } else {
  995. cursor.x_rot=Math_PI/2.0;
  996. set_message("Top View.",2);
  997. }
  998. } break;
  999. case KEY_KP_1: {
  1000. cursor.x_rot=0;
  1001. if (k.mod.shift) {
  1002. cursor.y_rot=Math_PI;
  1003. set_message("Rear View.",2);
  1004. } else {
  1005. cursor.y_rot=0;
  1006. set_message("Front View.",2);
  1007. }
  1008. } break;
  1009. case KEY_KP_3: {
  1010. cursor.x_rot=0;
  1011. if (k.mod.shift) {
  1012. cursor.y_rot=Math_PI/2.0;
  1013. set_message("Left View.",2);
  1014. } else {
  1015. cursor.y_rot=-Math_PI/2.0;
  1016. set_message("Right View.",2);
  1017. }
  1018. } break;
  1019. case KEY_KP_5: {
  1020. orthogonal = !orthogonal;
  1021. _menu_option(orthogonal?VIEW_PERSPECTIVE:VIEW_ORTHOGONAL);
  1022. } break;
  1023. case KEY_K: {
  1024. if (!get_selected_count() || _edit.mode!=TRANSFORM_NONE)
  1025. break;
  1026. if (!editor->get_animation_editor()->has_keying()) {
  1027. set_message("Keying is disabled (no key inserted).");
  1028. break;
  1029. }
  1030. List<Node*> &selection = editor_selection->get_selected_node_list();
  1031. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  1032. Spatial *sp = E->get()->cast_to<Spatial>();
  1033. if (!sp)
  1034. continue;
  1035. emit_signal("transform_key_request",sp,"",sp->get_transform());
  1036. }
  1037. set_message("Animation Key Inserted.");
  1038. } break;
  1039. case KEY_F: {
  1040. if (k.pressed && k.mod.shift && k.mod.control) {
  1041. _menu_option(VIEW_ALIGN_SELECTION_WITH_VIEW);
  1042. } else if (k.pressed) {
  1043. _menu_option(VIEW_CENTER_TO_SELECTION);
  1044. }
  1045. } break;
  1046. case KEY_SPACE: {
  1047. if (!k.pressed)
  1048. emit_signal("toggle_maximize_view", this);
  1049. } break;
  1050. }
  1051. } break;
  1052. }
  1053. }
  1054. void SpatialEditorViewport::set_message(String p_message,float p_time) {
  1055. message=p_message;
  1056. message_time=p_time;
  1057. }
  1058. void SpatialEditorViewport::_notification(int p_what) {
  1059. if (p_what==NOTIFICATION_VISIBILITY_CHANGED) {
  1060. bool visible=is_visible();
  1061. set_process(visible);
  1062. call_deferred("update_transform_gizmo_view");
  1063. }
  1064. if (p_what==NOTIFICATION_RESIZED) {
  1065. call_deferred("update_transform_gizmo_view");
  1066. }
  1067. if (p_what==NOTIFICATION_PROCESS) {
  1068. //force editr camera
  1069. /*
  1070. current_camera=get_root_node()->get_current_camera();
  1071. if (current_camera!=camera) {
  1072. }
  1073. */
  1074. if (orthogonal) {
  1075. Size2 size=get_size();
  1076. Size2 vpsize = Point2(cursor.distance*size.get_aspect(),cursor.distance/size.get_aspect());
  1077. //camera->set_orthogonal(size.width*cursor.distance,get_znear(),get_zfar());
  1078. camera->set_orthogonal(2*cursor.distance,0.1,8192);
  1079. } else
  1080. camera->set_perspective(get_fov(),get_znear(),get_zfar());
  1081. Transform camera_transform;
  1082. camera_transform.translate( cursor.pos );
  1083. camera_transform.basis.rotate(Vector3(0,1,0),cursor.y_rot);
  1084. camera_transform.basis.rotate(Vector3(1,0,0),cursor.x_rot);
  1085. if (orthogonal)
  1086. camera_transform.translate(0,0,4096);
  1087. else
  1088. camera_transform.translate(0,0,cursor.distance);
  1089. if (camera->get_global_transform()!=camera_transform) {
  1090. camera->set_global_transform( camera_transform );
  1091. update_transform_gizmo_view();
  1092. }
  1093. Map<Node*,Object*> &selection = editor_selection->get_selection();
  1094. bool changed=false;
  1095. bool exist=false;
  1096. for(Map<Node*,Object*>::Element *E=selection.front();E;E=E->next()) {
  1097. Spatial *sp = E->key()->cast_to<Spatial>();
  1098. if (!sp)
  1099. continue;
  1100. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  1101. if (!se)
  1102. continue;
  1103. /*
  1104. ??
  1105. if (!se->poly_instance.is_valid())
  1106. continue;
  1107. if (!ObjectDB::get_instance( E->key() )) {
  1108. VisualServer::get_singleton()->free( se->poly_instance );
  1109. se->poly_instance=RID();
  1110. continue;
  1111. }
  1112. */
  1113. VisualInstance *vi=sp->cast_to<VisualInstance>();
  1114. if (se->aabb.has_no_surface()) {
  1115. se->aabb=vi?vi->get_aabb():AABB( Vector3(-0.2,-0.2,-0.2),Vector3(0.4,0.4,0.4));
  1116. }
  1117. Transform t=sp->get_global_transform();
  1118. t.translate(se->aabb.pos);
  1119. t.basis.scale( se->aabb.size );
  1120. exist=true;
  1121. if (se->last_xform==t)
  1122. continue;
  1123. changed=true;
  1124. se->last_xform=t;
  1125. VisualServer::get_singleton()->instance_set_transform(se->sbox_instance,t);
  1126. }
  1127. if (changed || (spatial_editor->is_gizmo_visible() && !exist)) {
  1128. spatial_editor->update_transform_gizmo();
  1129. }
  1130. if (message_time>0) {
  1131. if (message!=last_message) {
  1132. surface->update();
  1133. last_message=message;
  1134. }
  1135. message_time-=get_fixed_process_delta_time();
  1136. if (message_time<0)
  1137. surface->update();
  1138. }
  1139. //grid
  1140. Vector3 grid_cam_axis=_get_camera_normal();
  1141. /*
  1142. for(int i=0;i<3;i++) {
  1143. Vector3 axis;
  1144. axis[i]=1;
  1145. bool should_be_visible= grid_enabled && (grid_enable[i] || (Math::abs(grid_cam_axis.dot(axis))>0.99 && orthogonal));
  1146. if (should_be_visible!=grid_visible[i]) {
  1147. VisualServer::get_singleton()->instance_geometry_set_flag(grid_instance[i],VS::INSTANCE_FLAG_VISIBLE,should_be_visible);
  1148. grid_visible[i]=should_be_visible;
  1149. }
  1150. }
  1151. if (last_grid_snap!=spatial_editor->get_translate_snap()) {
  1152. last_grid_snap=spatial_editor->get_translate_snap()
  1153. Transform gridt;
  1154. gridt.basis.scale(Vector3(last_grid_snap,last_grid_snap,last_grid_snap));
  1155. for(int i=0;i<3;i++)
  1156. VisualServer::get_singleton()->instance_set_transform(grid_instance[i],gridt);
  1157. }*/
  1158. }
  1159. if (p_what==NOTIFICATION_ENTER_SCENE) {
  1160. surface->connect("draw",this,"_draw");
  1161. surface->connect("input_event",this,"_sinput");
  1162. surface->connect("mouse_enter",this,"_smouseenter");
  1163. preview_camera->set_icon(get_icon("Camera","EditorIcons"));
  1164. _init_gizmo_instance(index);
  1165. }
  1166. if (p_what==NOTIFICATION_MOUSE_ENTER) {
  1167. }
  1168. if (p_what==NOTIFICATION_DRAW) {
  1169. }
  1170. }
  1171. void SpatialEditorViewport::_draw() {
  1172. if (surface->has_focus()) {
  1173. Size2 size = surface->get_size();
  1174. Rect2 r =Rect2(Point2(),size);
  1175. get_stylebox("EditorFocus","EditorStyles")->draw(surface->get_canvas_item(),r);
  1176. }
  1177. RID ci=surface->get_canvas_item();
  1178. if (cursor.region_select) {
  1179. VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(cursor.region_begin,cursor.region_end-cursor.region_begin),Color(0.7,0.7,1.0,0.3));
  1180. }
  1181. if (message_time>0) {
  1182. Ref<Font> font = get_font("font","Label");
  1183. Point2 msgpos=Point2(5,get_size().y-20);
  1184. font->draw(ci,msgpos+Point2(1,1),message,Color(0,0,0,0.8));
  1185. font->draw(ci,msgpos+Point2(-1,-1),message,Color(0,0,0,0.8));
  1186. font->draw(ci,msgpos,message,Color(1,1,1,1));
  1187. }
  1188. if (_edit.mode==TRANSFORM_ROTATE) {
  1189. Point2 center = _point_to_screen(_edit.center);
  1190. VisualServer::get_singleton()->canvas_item_add_line(ci,_edit.mouse_pos, center, Color(0.4,0.7,1.0,0.8));
  1191. }
  1192. if (previewing) {
  1193. Size2 ss = Size2( Globals::get_singleton()->get("display/width"), Globals::get_singleton()->get("display/height") );
  1194. float aspect = ss.get_aspect();
  1195. Size2 s = get_size();
  1196. Rect2 draw_rect;
  1197. switch(previewing->get_keep_aspect_mode()) {
  1198. case Camera::KEEP_WIDTH: {
  1199. draw_rect.size = Size2(s.width,s.width/aspect);
  1200. draw_rect.pos.x=0;
  1201. draw_rect.pos.y=(s.height-draw_rect.size.y)*0.5;
  1202. } break;
  1203. case Camera::KEEP_HEIGHT: {
  1204. draw_rect.size = Size2(s.height*aspect,s.height);
  1205. draw_rect.pos.y=0;
  1206. draw_rect.pos.x=(s.width-draw_rect.size.x)*0.5;
  1207. } break;
  1208. }
  1209. draw_rect = Rect2(Vector2(),s).clip(draw_rect);
  1210. surface->draw_line(draw_rect.pos,draw_rect.pos+Vector2(draw_rect.size.x,0),Color(0.6,0.6,0.1,0.5),2.0);
  1211. surface->draw_line(draw_rect.pos+Vector2(draw_rect.size.x,0),draw_rect.pos+draw_rect.size,Color(0.6,0.6,0.1,0.5),2.0);
  1212. surface->draw_line(draw_rect.pos+draw_rect.size,draw_rect.pos+Vector2(0,draw_rect.size.y),Color(0.6,0.6,0.1,0.5),2.0);
  1213. surface->draw_line(draw_rect.pos,draw_rect.pos+Vector2(0,draw_rect.size.y),Color(0.6,0.6,0.1,0.5),2.0);
  1214. }
  1215. }
  1216. void SpatialEditorViewport::_menu_option(int p_option) {
  1217. switch(p_option) {
  1218. case VIEW_TOP: {
  1219. cursor.x_rot=Math_PI/2.0;
  1220. cursor.y_rot=0;
  1221. } break;
  1222. case VIEW_BOTTOM: {
  1223. cursor.x_rot=-Math_PI/2.0;
  1224. cursor.y_rot=0;
  1225. } break;
  1226. case VIEW_LEFT: {
  1227. cursor.y_rot=Math_PI/2.0;
  1228. cursor.x_rot=0;
  1229. } break;
  1230. case VIEW_RIGHT: {
  1231. cursor.y_rot=-Math_PI/2.0;
  1232. cursor.x_rot=0;
  1233. } break;
  1234. case VIEW_FRONT: {
  1235. cursor.y_rot=0;
  1236. cursor.x_rot=0;
  1237. } break;
  1238. case VIEW_REAR: {
  1239. cursor.y_rot=Math_PI;
  1240. cursor.x_rot=0;
  1241. } break;
  1242. case VIEW_CENTER_TO_SELECTION: {
  1243. if (!get_selected_count())
  1244. break;
  1245. Vector3 center;
  1246. int count=0;
  1247. List<Node*> &selection = editor_selection->get_selected_node_list();
  1248. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  1249. Spatial *sp = E->get()->cast_to<Spatial>();
  1250. if (!sp)
  1251. continue;
  1252. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  1253. if (!se)
  1254. continue;
  1255. center+=sp->get_global_transform().origin;
  1256. count++;
  1257. }
  1258. center/=float(count);
  1259. cursor.pos=center;
  1260. } break;
  1261. case VIEW_ALIGN_SELECTION_WITH_VIEW: {
  1262. if (!get_selected_count())
  1263. break;
  1264. Transform camera_transform = camera->get_global_transform();
  1265. List<Node*> &selection = editor_selection->get_selected_node_list();
  1266. undo_redo->create_action("Align with view");
  1267. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  1268. Spatial *sp = E->get()->cast_to<Spatial>();
  1269. if (!sp)
  1270. continue;
  1271. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  1272. if (!se)
  1273. continue;
  1274. Vector3 original_scale = sp->get_scale();
  1275. sp->set_global_transform(camera_transform);
  1276. sp->set_scale(original_scale);
  1277. undo_redo->add_do_method(sp,"set_global_transform",sp->get_global_transform());
  1278. undo_redo->add_undo_method(sp,"set_global_transform",se->original);
  1279. }
  1280. undo_redo->commit_action();
  1281. } break;
  1282. case VIEW_ENVIRONMENT: {
  1283. int idx = view_menu->get_popup()->get_item_index(VIEW_ENVIRONMENT);
  1284. bool current = view_menu->get_popup()->is_item_checked( idx );
  1285. current=!current;
  1286. if (current) {
  1287. camera->set_environment(RES());
  1288. } else {
  1289. camera->set_environment(SpatialEditor::get_singleton()->get_viewport_environment());
  1290. }
  1291. view_menu->get_popup()->set_item_checked( idx, current );
  1292. } break;
  1293. case VIEW_PERSPECTIVE: {
  1294. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(VIEW_PERSPECTIVE), true );
  1295. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(VIEW_ORTHOGONAL), false );
  1296. orthogonal=false;
  1297. call_deferred("update_transform_gizmo_view");
  1298. } break;
  1299. case VIEW_ORTHOGONAL: {
  1300. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(VIEW_PERSPECTIVE), false );
  1301. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(VIEW_ORTHOGONAL), true );
  1302. orthogonal=true;
  1303. call_deferred("update_transform_gizmo_view");
  1304. } break;
  1305. }
  1306. }
  1307. void SpatialEditorViewport::_preview_exited_scene() {
  1308. preview_camera->set_pressed(false);
  1309. _toggle_camera_preview(false);
  1310. view_menu->show();
  1311. }
  1312. void SpatialEditorViewport::_init_gizmo_instance(int p_idx) {
  1313. uint32_t layer=1<<(GIZMO_BASE_LAYER+p_idx);
  1314. for(int i=0;i<3;i++) {
  1315. move_gizmo_instance[i]=VS::get_singleton()->instance_create();
  1316. VS::get_singleton()->instance_set_base(move_gizmo_instance[i],spatial_editor->get_move_gizmo(i)->get_rid());
  1317. VS::get_singleton()->instance_set_scenario(move_gizmo_instance[i],get_scene()->get_root()->get_world()->get_scenario());
  1318. VS::get_singleton()->instance_geometry_set_flag(move_gizmo_instance[i],VS::INSTANCE_FLAG_VISIBLE,false);
  1319. //VS::get_singleton()->instance_geometry_set_flag(move_gizmo_instance[i],VS::INSTANCE_FLAG_DEPH_SCALE,true);
  1320. VS::get_singleton()->instance_geometry_set_flag(move_gizmo_instance[i],VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1321. VS::get_singleton()->instance_set_layer_mask(move_gizmo_instance[i],layer);
  1322. rotate_gizmo_instance[i]=VS::get_singleton()->instance_create();
  1323. VS::get_singleton()->instance_set_base(rotate_gizmo_instance[i],spatial_editor->get_rotate_gizmo(i)->get_rid());
  1324. VS::get_singleton()->instance_set_scenario(rotate_gizmo_instance[i],get_scene()->get_root()->get_world()->get_scenario());
  1325. VS::get_singleton()->instance_geometry_set_flag(rotate_gizmo_instance[i],VS::INSTANCE_FLAG_VISIBLE,false);
  1326. //VS::get_singleton()->instance_geometry_set_flag(rotate_gizmo_instance[i],VS::INSTANCE_FLAG_DEPH_SCALE,true);
  1327. VS::get_singleton()->instance_geometry_set_flag(rotate_gizmo_instance[i],VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1328. VS::get_singleton()->instance_set_layer_mask(rotate_gizmo_instance[i],layer);
  1329. }
  1330. }
  1331. void SpatialEditorViewport::_toggle_camera_preview(bool p_activate) {
  1332. ERR_FAIL_COND(p_activate && !preview);
  1333. ERR_FAIL_COND(!p_activate && !previewing);
  1334. if (!p_activate) {
  1335. previewing->disconnect("exit_scene",this,"_preview_exited_scene");
  1336. previewing=NULL;
  1337. VS::get_singleton()->viewport_attach_camera( viewport->get_viewport(), camera->get_camera() ); //restore
  1338. if (!preview)
  1339. preview_camera->hide();
  1340. view_menu->show();
  1341. surface->update();
  1342. } else {
  1343. previewing=preview;
  1344. previewing->connect("exit_scene",this,"_preview_exited_scene");
  1345. VS::get_singleton()->viewport_attach_camera( viewport->get_viewport(), preview->get_camera() ); //replace
  1346. view_menu->hide();
  1347. surface->update();
  1348. }
  1349. }
  1350. void SpatialEditorViewport::set_can_preview(Camera* p_preview) {
  1351. preview=p_preview;
  1352. if (!preview_camera->is_pressed()) {
  1353. if (p_preview) {
  1354. preview_camera->show();
  1355. } else {
  1356. preview_camera->hide();
  1357. }
  1358. }
  1359. }
  1360. void SpatialEditorViewport::update_transform_gizmo_view() {
  1361. if (!is_visible())
  1362. return;
  1363. Transform xform = spatial_editor->get_gizmo_transform();
  1364. Transform camera_xform = camera->get_transform();
  1365. Vector3 camz = -camera_xform.get_basis().get_axis(2).normalized();
  1366. Vector3 camy = -camera_xform.get_basis().get_axis(1).normalized();
  1367. Plane p(camera_xform.origin,camz);
  1368. float gizmo_d = Math::abs( p.distance_to(xform.origin ));
  1369. float d0 = camera->unproject_position(camera_xform.origin+camz*gizmo_d).y;
  1370. float d1 = camera->unproject_position(camera_xform.origin+camz*gizmo_d+camy).y;
  1371. float dd = Math::abs(d0-d1);
  1372. if (dd==0)
  1373. dd=0.0001;
  1374. float gsize = EditorSettings::get_singleton()->get("3d_editor/manipulator_gizmo_size");
  1375. gizmo_scale=(gsize/Math::abs(dd));
  1376. Vector3 scale = Vector3(1,1,1) * gizmo_scale;
  1377. xform.basis.scale(scale);
  1378. //xform.basis.scale(GIZMO_SCALE_DEFAULT*Vector3(1,1,1));
  1379. for(int i=0;i<3;i++) {
  1380. VisualServer::get_singleton()->instance_set_transform(move_gizmo_instance[i], xform );
  1381. VisualServer::get_singleton()->instance_geometry_set_flag(move_gizmo_instance[i],VS::INSTANCE_FLAG_VISIBLE,spatial_editor->is_gizmo_visible()&& (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_MOVE) );
  1382. VisualServer::get_singleton()->instance_set_transform(rotate_gizmo_instance[i], xform );
  1383. VisualServer::get_singleton()->instance_geometry_set_flag(rotate_gizmo_instance[i],VS::INSTANCE_FLAG_VISIBLE,spatial_editor->is_gizmo_visible() && (spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_SELECT || spatial_editor->get_tool_mode()==SpatialEditor::TOOL_MODE_ROTATE) );
  1384. }
  1385. }
  1386. void SpatialEditorViewport::set_state(const Dictionary& p_state) {
  1387. cursor.pos=p_state["pos"];
  1388. cursor.x_rot=p_state["x_rot"];
  1389. cursor.y_rot=p_state["y_rot"];
  1390. cursor.distance=p_state["distance"];
  1391. bool env = p_state["use_environment"];
  1392. bool orth = p_state["use_orthogonal"];
  1393. if (orth)
  1394. _menu_option(VIEW_ORTHOGONAL);
  1395. else
  1396. _menu_option(VIEW_PERSPECTIVE);
  1397. if (env != camera->get_environment().is_valid())
  1398. _menu_option(VIEW_ENVIRONMENT);
  1399. }
  1400. Dictionary SpatialEditorViewport::get_state() const {
  1401. Dictionary d;
  1402. d["pos"]=cursor.pos;
  1403. d["x_rot"]=cursor.x_rot;
  1404. d["y_rot"]=cursor.y_rot;
  1405. d["distance"]=cursor.distance;
  1406. d["use_environment"]=camera->get_environment().is_valid();
  1407. d["use_orthogonal"]=camera->get_projection()==Camera::PROJECTION_ORTHOGONAL;
  1408. return d;
  1409. }
  1410. void SpatialEditorViewport::_bind_methods(){
  1411. ObjectTypeDB::bind_method(_MD("_draw"),&SpatialEditorViewport::_draw);
  1412. ObjectTypeDB::bind_method(_MD("_smouseenter"),&SpatialEditorViewport::_smouseenter);
  1413. ObjectTypeDB::bind_method(_MD("_sinput"),&SpatialEditorViewport::_sinput);
  1414. ObjectTypeDB::bind_method(_MD("_menu_option"),&SpatialEditorViewport::_menu_option);
  1415. ObjectTypeDB::bind_method(_MD("_toggle_camera_preview"),&SpatialEditorViewport::_toggle_camera_preview);
  1416. ObjectTypeDB::bind_method(_MD("_preview_exited_scene"),&SpatialEditorViewport::_preview_exited_scene);
  1417. ObjectTypeDB::bind_method(_MD("update_transform_gizmo_view"),&SpatialEditorViewport::update_transform_gizmo_view);
  1418. ADD_SIGNAL( MethodInfo("toggle_maximize_view", PropertyInfo(Variant::OBJECT, "viewport")) );
  1419. }
  1420. SpatialEditorViewport::SpatialEditorViewport(SpatialEditor *p_spatial_editor, EditorNode *p_editor, int p_index) {
  1421. index=p_index;
  1422. editor=p_editor;
  1423. editor_selection=editor->get_editor_selection();;
  1424. undo_redo=editor->get_undo_redo();
  1425. clicked=0;
  1426. clicked_includes_current=false;
  1427. orthogonal=false;
  1428. message_time=0;
  1429. spatial_editor=p_spatial_editor;
  1430. Control *c=memnew(Control);
  1431. add_child(c);
  1432. c->set_area_as_parent_rect();
  1433. viewport = memnew( Viewport );
  1434. c->add_child(viewport);
  1435. surface = memnew( Control );
  1436. add_child(surface);
  1437. surface->set_area_as_parent_rect();
  1438. camera = memnew(Camera);
  1439. camera->set_disable_gizmo(true);
  1440. camera->set_visible_layers( ((1<<20)-1)|(1<<(GIZMO_BASE_LAYER+p_index)) );
  1441. //camera->set_environment(SpatialEditor::get_singleton()->get_viewport_environment());
  1442. viewport->add_child(camera);
  1443. camera->make_current();
  1444. surface->set_focus_mode(FOCUS_ALL);
  1445. view_menu = memnew( MenuButton );
  1446. surface->add_child(view_menu);
  1447. view_menu->set_pos( Point2(4,4));
  1448. view_menu->set_text("[view]");
  1449. view_menu->set_self_opacity(0.5);
  1450. view_menu->get_popup()->add_item("Top",VIEW_TOP);
  1451. view_menu->get_popup()->add_item("Bottom",VIEW_BOTTOM);
  1452. view_menu->get_popup()->add_item("Left",VIEW_LEFT);
  1453. view_menu->get_popup()->add_item("Right",VIEW_RIGHT);
  1454. view_menu->get_popup()->add_item("Front",VIEW_FRONT);
  1455. view_menu->get_popup()->add_item("Rear",VIEW_REAR);
  1456. view_menu->get_popup()->add_separator();
  1457. view_menu->get_popup()->add_check_item("Perspective",VIEW_PERSPECTIVE);
  1458. view_menu->get_popup()->add_check_item("Orthogonal",VIEW_ORTHOGONAL);
  1459. view_menu->get_popup()->set_item_checked(view_menu->get_popup()->get_item_index(VIEW_PERSPECTIVE),true);
  1460. view_menu->get_popup()->add_separator();
  1461. view_menu->get_popup()->add_check_item("Environment",VIEW_ENVIRONMENT);
  1462. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(VIEW_ENVIRONMENT),true);
  1463. view_menu->get_popup()->add_separator();
  1464. view_menu->get_popup()->add_item("Selection (F)",VIEW_CENTER_TO_SELECTION);
  1465. view_menu->get_popup()->add_item("Align with view (Ctrl+Shift+F)",VIEW_ALIGN_SELECTION_WITH_VIEW);
  1466. view_menu->get_popup()->connect("item_pressed",this,"_menu_option");
  1467. preview_camera = memnew( Button );
  1468. preview_camera->set_toggle_mode(true);
  1469. preview_camera->set_anchor_and_margin(MARGIN_LEFT,ANCHOR_END,90);
  1470. preview_camera->set_anchor_and_margin(MARGIN_TOP,ANCHOR_BEGIN,10);
  1471. preview_camera->set_text("preview");
  1472. surface->add_child(preview_camera);
  1473. preview_camera->hide();
  1474. preview_camera->connect("toggled",this,"_toggle_camera_preview");
  1475. previewing=NULL;
  1476. preview=NULL;
  1477. gizmo_scale=1.0;
  1478. EditorSettings::get_singleton()->connect("settings_changed",this,"update_transform_gizmo_view");
  1479. }
  1480. SpatialEditor *SpatialEditor::singleton=NULL;
  1481. SpatialEditorSelectedItem::~SpatialEditorSelectedItem() {
  1482. if (sbox_instance.is_valid())
  1483. VisualServer::get_singleton()->free(sbox_instance);
  1484. }
  1485. void SpatialEditor::select_gizmo_hilight_axis(int p_axis) {
  1486. for(int i=0;i<3;i++) {
  1487. move_gizmo[i]->surface_set_material(0,i==p_axis?gizmo_hl:gizmo_color[i]);
  1488. rotate_gizmo[i]->surface_set_material(0,(i+3)==p_axis?gizmo_hl:gizmo_color[i]);
  1489. }
  1490. }
  1491. void SpatialEditor::update_transform_gizmo() {
  1492. List<Node*> &selection = editor_selection->get_selected_node_list();
  1493. AABB center;
  1494. bool first=true;
  1495. Matrix3 gizmo_basis;
  1496. bool local_gizmo_coords = transform_menu->get_popup()->is_item_checked( transform_menu->get_popup()->get_item_index(MENU_TRANSFORM_LOCAL_COORDS) );
  1497. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  1498. Spatial *sp = E->get()->cast_to<Spatial>();
  1499. if (!sp)
  1500. continue;
  1501. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  1502. if (!se)
  1503. continue;
  1504. Transform xf = se->sp->get_global_transform();
  1505. if (first) {
  1506. center.pos=xf.origin;
  1507. first=false;
  1508. if (local_gizmo_coords) {
  1509. gizmo_basis=xf.basis;
  1510. gizmo_basis.orthonormalize();
  1511. }
  1512. } else {
  1513. center.expand_to(xf.origin);
  1514. gizmo_basis=Matrix3();
  1515. }
  1516. // count++;
  1517. }
  1518. Vector3 pcenter = center.pos+center.size*0.5;
  1519. gizmo.visible=!first;
  1520. gizmo.transform.origin=pcenter;
  1521. gizmo.transform.basis=gizmo_basis;
  1522. for(int i=0;i<4;i++) {
  1523. viewports[i]->update_transform_gizmo_view();
  1524. }
  1525. }
  1526. Object *SpatialEditor::_get_editor_data(Object *p_what) {
  1527. Spatial *sp = p_what->cast_to<Spatial>();
  1528. if (!sp)
  1529. return NULL;
  1530. SpatialEditorSelectedItem *si = memnew( SpatialEditorSelectedItem );
  1531. si->sp=sp;
  1532. si->sbox_instance=VisualServer::get_singleton()->instance_create2(selection_box->get_rid(),sp->get_world()->get_scenario());
  1533. VS::get_singleton()->instance_geometry_set_flag(si->sbox_instance,VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1534. RID inst = sp->call("_get_visual_instance_rid");
  1535. // if (inst.is_valid())
  1536. // si->aabb = VisualServer::get_singleton()->instance_get_base_aabb(inst);
  1537. if (get_scene()->is_editor_hint())
  1538. editor->call("edit_node",sp);
  1539. return si;
  1540. }
  1541. void SpatialEditor::_generate_selection_box() {
  1542. AABB aabb( Vector3(), Vector3(1,1,1) );
  1543. aabb.grow_by( aabb.get_longest_axis_size()/20.0 );
  1544. Ref<SurfaceTool> st = memnew( SurfaceTool );
  1545. st->begin(Mesh::PRIMITIVE_LINES);
  1546. for (int i=0;i<12;i++) {
  1547. Vector3 a,b;
  1548. aabb.get_edge(i,a,b);
  1549. /*Vector<Vector3> points;
  1550. Vector<Color> colors;
  1551. points.push_back(a);
  1552. points.push_back(b);*/
  1553. st->add_color( Color(1.0,1.0,0.8,0.8) );
  1554. st->add_vertex(a);
  1555. st->add_color( Color(1.0,1.0,0.8,0.4) );
  1556. st->add_vertex(a.linear_interpolate(b,0.2));
  1557. st->add_color( Color(1.0,1.0,0.8,0.4) );
  1558. st->add_vertex(a.linear_interpolate(b,0.8));
  1559. st->add_color( Color(1.0,1.0,0.8,0.8) );
  1560. st->add_vertex(b);
  1561. }
  1562. Ref<FixedMaterial> mat = memnew( FixedMaterial );
  1563. mat->set_flag(Material::FLAG_UNSHADED,true);
  1564. mat->set_parameter(FixedMaterial::PARAM_DIFFUSE,Color(1,1,1));
  1565. mat->set_fixed_flag(FixedMaterial::FLAG_USE_ALPHA,true);
  1566. mat->set_fixed_flag(FixedMaterial::FLAG_USE_COLOR_ARRAY,true);
  1567. st->set_material(mat);
  1568. selection_box = st->commit();
  1569. }
  1570. Dictionary SpatialEditor::get_state() const {
  1571. Dictionary d;
  1572. int vc=0;
  1573. if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT) ))
  1574. vc=1;
  1575. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS) ))
  1576. vc=2;
  1577. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS) ))
  1578. vc=3;
  1579. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS) ))
  1580. vc=4;
  1581. d["viewport_mode"]=vc;
  1582. Array vpdata;
  1583. for(int i=0;i<4;i++) {
  1584. vpdata.push_back( viewports[i]->get_state() );
  1585. }
  1586. d["viewports"]=vpdata;
  1587. d["default_light"]=view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_DEFAULT_LIGHT) );;
  1588. d["show_grid"]=view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_GRID) );;
  1589. d["show_origin"]=view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_ORIGIN) );;
  1590. d["fov"]=get_fov();
  1591. d["znear"]=get_znear();
  1592. d["zfar"]=get_zfar();
  1593. return d;
  1594. }
  1595. void SpatialEditor::set_state(const Dictionary& p_state) {
  1596. Dictionary d = p_state;
  1597. ERR_FAIL_COND(!d.has("viewport_mode"));
  1598. ERR_FAIL_COND(!d.has("viewports"));
  1599. ERR_FAIL_COND(!d.has("default_light"));
  1600. ERR_FAIL_COND(!d.has("show_grid"));
  1601. ERR_FAIL_COND(!d.has("show_origin"));
  1602. ERR_FAIL_COND(!d.has("fov"));
  1603. ERR_FAIL_COND(!d.has("znear"));
  1604. ERR_FAIL_COND(!d.has("zfar"));
  1605. int vc = d["viewport_mode"];
  1606. if (vc==1)
  1607. _menu_item_pressed(MENU_VIEW_USE_1_VIEWPORT);
  1608. else if (vc==2)
  1609. _menu_item_pressed(MENU_VIEW_USE_2_VIEWPORTS);
  1610. else if (vc==3)
  1611. _menu_item_pressed(MENU_VIEW_USE_3_VIEWPORTS);
  1612. else if (vc==4)
  1613. _menu_item_pressed(MENU_VIEW_USE_4_VIEWPORTS);
  1614. Array vp = d["viewports"];
  1615. ERR_FAIL_COND(vp.size()>4);
  1616. for(int i=0;i<4;i++) {
  1617. viewports[i]->set_state(vp[i]);
  1618. }
  1619. if (d.has("zfar"))
  1620. settings_zfar->set_text(d["zfar"]);
  1621. if (d.has("znear"))
  1622. settings_znear->set_text(d["znear"]);
  1623. if (d.has("fov"))
  1624. settings_fov->set_text(d["fov"]);
  1625. if (d.has("default_light")) {
  1626. bool use = d["default_light"];
  1627. bool existing = light_instance.is_valid();
  1628. if (use!=existing) {
  1629. if (existing) {
  1630. VisualServer::get_singleton()->free(light_instance);
  1631. light_instance=RID();
  1632. } else {
  1633. light_instance=VisualServer::get_singleton()->instance_create2(light,get_scene()->get_root()->get_world()->get_scenario());
  1634. VisualServer::get_singleton()->instance_set_transform(light_instance,light_transform);
  1635. }
  1636. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_DEFAULT_LIGHT), light_instance.is_valid() );
  1637. }
  1638. }
  1639. if (d.has("show_grid")) {
  1640. bool use = d["show_grid"];
  1641. if (use!=view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_GRID))) {
  1642. _menu_item_pressed(MENU_VIEW_GRID);
  1643. }
  1644. }
  1645. if (d.has("show_origin")) {
  1646. bool use = d["show_origin"];
  1647. if (use!=view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_ORIGIN))) {
  1648. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_ORIGIN), use );
  1649. VisualServer::get_singleton()->instance_geometry_set_flag(origin_instance,VS::INSTANCE_FLAG_VISIBLE,use);
  1650. }
  1651. }
  1652. }
  1653. void SpatialEditor::edit(Spatial *p_spatial) {
  1654. if (p_spatial!=selected) {
  1655. if (selected) {
  1656. Ref<SpatialEditorGizmo> seg = selected->get_gizmo();
  1657. if (seg.is_valid()) {
  1658. seg->set_selected(false);
  1659. selected->update_gizmo();
  1660. }
  1661. }
  1662. selected=p_spatial;
  1663. over_gizmo_handle=-1;
  1664. if (selected) {
  1665. Ref<SpatialEditorGizmo> seg = selected->get_gizmo();
  1666. if (seg.is_valid()) {
  1667. seg->set_selected(true);
  1668. selected->update_gizmo();
  1669. }
  1670. }
  1671. }
  1672. if (p_spatial) {
  1673. //_validate_selection();
  1674. //if (selected.has(p_spatial->get_instance_ID()) && selected.size()==1)
  1675. // return;
  1676. //_select(p_spatial->get_instance_ID(),false,true);
  1677. // should become the selection
  1678. }
  1679. }
  1680. void SpatialEditor::_xform_dialog_action() {
  1681. Transform t;
  1682. //translation
  1683. Vector3 scale;
  1684. Vector3 rotate;
  1685. Vector3 translate;
  1686. for(int i=0;i<3;i++) {
  1687. translate[i]=xform_translate[i]->get_text().to_double();
  1688. rotate[i]=Math::deg2rad(xform_rotate[i]->get_text().to_double());
  1689. scale[i]=xform_scale[i]->get_text().to_double();
  1690. }
  1691. t.origin=translate;
  1692. for(int i=0;i<3;i++) {
  1693. if (!rotate[i])
  1694. continue;
  1695. Vector3 axis;
  1696. axis[i]=1.0;
  1697. t.basis.rotate(axis,rotate[i]);
  1698. }
  1699. for(int i=0;i<3;i++) {
  1700. if (scale[i]==1)
  1701. continue;
  1702. t.basis.set_axis(i,t.basis.get_axis(i)*scale[i]);
  1703. }
  1704. undo_redo->create_action("XForm Dialog");
  1705. List<Node*> &selection = editor_selection->get_selected_node_list();
  1706. for(List<Node*>::Element *E=selection.front();E;E=E->next()) {
  1707. Spatial *sp = E->get()->cast_to<Spatial>();
  1708. if (!sp)
  1709. continue;
  1710. SpatialEditorSelectedItem *se=editor_selection->get_node_editor_data<SpatialEditorSelectedItem>(sp);
  1711. if (!se)
  1712. continue;
  1713. bool post = xform_type->get_selected()>0;
  1714. Transform tr = sp->get_global_transform();
  1715. if (post)
  1716. tr = tr * t;
  1717. else {
  1718. tr.basis = t.basis * tr.basis;
  1719. tr.origin+=t.origin;
  1720. }
  1721. undo_redo->add_do_method(sp,"set_global_transform",tr);
  1722. undo_redo->add_undo_method(sp,"set_global_transform",sp->get_global_transform());
  1723. }
  1724. undo_redo->commit_action();
  1725. }
  1726. void SpatialEditor::_menu_item_pressed(int p_option) {
  1727. switch(p_option) {
  1728. case MENU_TOOL_SELECT:
  1729. case MENU_TOOL_MOVE:
  1730. case MENU_TOOL_ROTATE:
  1731. case MENU_TOOL_SCALE: {
  1732. for(int i=0;i<4;i++)
  1733. tool_button[i]->set_pressed(i==p_option);
  1734. tool_mode=(ToolMode)p_option;
  1735. static const char *_mode[]={"Selection Mode.","Translation Mode.","Rotation Mode.","Scale Mode."};
  1736. // set_message(_mode[p_option],3);
  1737. update_transform_gizmo();
  1738. } break;
  1739. case MENU_TRANSFORM_USE_SNAP: {
  1740. bool is_checked = transform_menu->get_popup()->is_item_checked( transform_menu->get_popup()->get_item_index(p_option) );
  1741. snap_enabled=!is_checked;
  1742. transform_menu->get_popup()->set_item_checked( transform_menu->get_popup()->get_item_index(p_option), snap_enabled );
  1743. } break;
  1744. case MENU_TRANSFORM_CONFIGURE_SNAP: {
  1745. snap_dialog->popup_centered(Size2(200,160));
  1746. } break;
  1747. case MENU_TRANSFORM_LOCAL_COORDS: {
  1748. bool is_checked = transform_menu->get_popup()->is_item_checked( transform_menu->get_popup()->get_item_index(p_option) );
  1749. transform_menu->get_popup()->set_item_checked( transform_menu->get_popup()->get_item_index(p_option), !is_checked );
  1750. update_transform_gizmo();
  1751. } break;
  1752. case MENU_TRANSFORM_DIALOG: {
  1753. for(int i=0;i<3;i++) {
  1754. xform_translate[i]->set_text("0");
  1755. xform_rotate[i]->set_text("0");
  1756. xform_scale[i]->set_text("1");
  1757. }
  1758. xform_dialog->popup_centered(Size2(200,200));
  1759. } break;
  1760. case MENU_VIEW_USE_DEFAULT_LIGHT: {
  1761. bool is_checked = view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(p_option) );
  1762. if (is_checked) {
  1763. VisualServer::get_singleton()->free(light_instance);
  1764. light_instance=RID();
  1765. } else {
  1766. light_instance=VisualServer::get_singleton()->instance_create2(light,get_scene()->get_root()->get_world()->get_scenario());
  1767. VisualServer::get_singleton()->instance_set_transform(light_instance,light_transform);
  1768. }
  1769. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(p_option), light_instance.is_valid() );
  1770. } break;
  1771. case MENU_VIEW_USE_1_VIEWPORT: {
  1772. for(int i=1;i<4;i++) {
  1773. viewports[i]->hide();
  1774. }
  1775. viewports[0]->set_area_as_parent_rect();
  1776. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT), true );
  1777. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS), false );
  1778. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS), false );
  1779. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS), false );
  1780. } break;
  1781. case MENU_VIEW_USE_2_VIEWPORTS: {
  1782. for(int i=1;i<4;i++) {
  1783. if (i==1 || i==3)
  1784. viewports[i]->hide();
  1785. else
  1786. viewports[i]->show();
  1787. }
  1788. viewports[0]->set_area_as_parent_rect();
  1789. viewports[0]->set_anchor_and_margin(MARGIN_BOTTOM,ANCHOR_RATIO,0.5);
  1790. viewports[2]->set_area_as_parent_rect();
  1791. viewports[2]->set_anchor_and_margin(MARGIN_TOP,ANCHOR_RATIO,0.5);
  1792. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT), false );
  1793. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS), true );
  1794. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS), false );
  1795. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS), false );
  1796. } break;
  1797. case MENU_VIEW_USE_3_VIEWPORTS: {
  1798. for(int i=1;i<4;i++) {
  1799. if (i==1)
  1800. viewports[i]->hide();
  1801. else
  1802. viewports[i]->show();
  1803. }
  1804. viewports[0]->set_area_as_parent_rect();
  1805. viewports[0]->set_anchor_and_margin(MARGIN_BOTTOM,ANCHOR_RATIO,0.5);
  1806. viewports[2]->set_area_as_parent_rect();
  1807. viewports[2]->set_anchor_and_margin(MARGIN_RIGHT,ANCHOR_RATIO,0.5);
  1808. viewports[2]->set_anchor_and_margin(MARGIN_TOP,ANCHOR_RATIO,0.5);
  1809. viewports[3]->set_area_as_parent_rect();
  1810. viewports[3]->set_anchor_and_margin(MARGIN_LEFT,ANCHOR_RATIO,0.5);
  1811. viewports[3]->set_anchor_and_margin(MARGIN_TOP,ANCHOR_RATIO,0.5);
  1812. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT), false );
  1813. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS), false );
  1814. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS), true );
  1815. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS), false );
  1816. } break;
  1817. case MENU_VIEW_USE_4_VIEWPORTS: {
  1818. for(int i=1;i<4;i++) {
  1819. viewports[i]->show();
  1820. }
  1821. viewports[0]->set_area_as_parent_rect();
  1822. viewports[0]->set_anchor_and_margin(MARGIN_RIGHT,ANCHOR_RATIO,0.5);
  1823. viewports[0]->set_anchor_and_margin(MARGIN_BOTTOM,ANCHOR_RATIO,0.5);
  1824. viewports[1]->set_area_as_parent_rect();
  1825. viewports[1]->set_anchor_and_margin(MARGIN_LEFT,ANCHOR_RATIO,0.5);
  1826. viewports[1]->set_anchor_and_margin(MARGIN_BOTTOM,ANCHOR_RATIO,0.5);
  1827. viewports[2]->set_area_as_parent_rect();
  1828. viewports[2]->set_anchor_and_margin(MARGIN_RIGHT,ANCHOR_RATIO,0.5);
  1829. viewports[2]->set_anchor_and_margin(MARGIN_TOP,ANCHOR_RATIO,0.5);
  1830. viewports[3]->set_area_as_parent_rect();
  1831. viewports[3]->set_anchor_and_margin(MARGIN_LEFT,ANCHOR_RATIO,0.5);
  1832. viewports[3]->set_anchor_and_margin(MARGIN_TOP,ANCHOR_RATIO,0.5);
  1833. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT), false );
  1834. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS), false );
  1835. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS), false );
  1836. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS), true );
  1837. } break;
  1838. case MENU_VIEW_DISPLAY_NORMAL: {
  1839. VisualServer::get_singleton()->scenario_set_debug( get_scene()->get_root()->get_world()->get_scenario(), VisualServer::SCENARIO_DEBUG_DISABLED );
  1840. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_NORMAL), true );
  1841. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_WIREFRAME), false );
  1842. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_OVERDRAW), false );
  1843. } break;
  1844. case MENU_VIEW_DISPLAY_WIREFRAME: {
  1845. VisualServer::get_singleton()->scenario_set_debug( get_scene()->get_root()->get_world()->get_scenario(), VisualServer::SCENARIO_DEBUG_WIREFRAME );
  1846. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_NORMAL), false );
  1847. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_WIREFRAME), true );
  1848. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_OVERDRAW), false );
  1849. } break;
  1850. case MENU_VIEW_DISPLAY_OVERDRAW: {
  1851. VisualServer::get_singleton()->scenario_set_debug( get_scene()->get_root()->get_world()->get_scenario(), VisualServer::SCENARIO_DEBUG_OVERDRAW );
  1852. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_NORMAL), false );
  1853. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_WIREFRAME), false );
  1854. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_DISPLAY_OVERDRAW), true );
  1855. } break;
  1856. case MENU_VIEW_ORIGIN: {
  1857. bool is_checked = view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(p_option) );
  1858. is_checked=!is_checked;
  1859. VisualServer::get_singleton()->instance_geometry_set_flag(origin_instance,VS::INSTANCE_FLAG_VISIBLE,is_checked);
  1860. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(p_option), is_checked);
  1861. } break;
  1862. case MENU_VIEW_GRID: {
  1863. bool is_checked = view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(p_option) );
  1864. grid_enabled=!is_checked;
  1865. for(int i=0;i<3;++i) {
  1866. if (grid_enable[i]) {
  1867. VisualServer::get_singleton()->instance_geometry_set_flag(grid_instance[i],VS::INSTANCE_FLAG_VISIBLE,grid_enabled);
  1868. grid_visible[i]=grid_enabled;
  1869. }
  1870. }
  1871. view_menu->get_popup()->set_item_checked( view_menu->get_popup()->get_item_index(p_option), grid_enabled );
  1872. } break;
  1873. case MENU_VIEW_CAMERA_SETTINGS: {
  1874. settings_dialog->popup_centered(Size2(200,160));
  1875. } break;
  1876. }
  1877. }
  1878. void SpatialEditor::_init_indicators() {
  1879. //make sure that the camera indicator is not selectable
  1880. light=VisualServer::get_singleton()->light_create( VisualServer::LIGHT_DIRECTIONAL );
  1881. //VisualServer::get_singleton()->light_set_shadow( light, true );
  1882. light_instance=VisualServer::get_singleton()->instance_create2(light,get_scene()->get_root()->get_world()->get_scenario());
  1883. light_transform.rotate(Vector3(1,0,0),Math_PI/5.0);
  1884. VisualServer::get_singleton()->instance_set_transform(light_instance,light_transform);
  1885. RID mat = VisualServer::get_singleton()->fixed_material_create();
  1886. VisualServer::get_singleton()->fixed_material_set_flag(mat, VisualServer::FIXED_MATERIAL_FLAG_USE_ALPHA,true);
  1887. VisualServer::get_singleton()->fixed_material_set_flag(mat, VisualServer::FIXED_MATERIAL_FLAG_USE_COLOR_ARRAY,true);
  1888. {
  1889. RID indicator_mat = VisualServer::get_singleton()->fixed_material_create();
  1890. VisualServer::get_singleton()->material_set_flag( indicator_mat, VisualServer::MATERIAL_FLAG_UNSHADED, true );
  1891. VisualServer::get_singleton()->material_set_flag( indicator_mat, VisualServer::MATERIAL_FLAG_ONTOP, false );
  1892. VisualServer::get_singleton()->fixed_material_set_flag(indicator_mat, VisualServer::FIXED_MATERIAL_FLAG_USE_ALPHA,true);
  1893. VisualServer::get_singleton()->fixed_material_set_flag(indicator_mat, VisualServer::FIXED_MATERIAL_FLAG_USE_COLOR_ARRAY,true);
  1894. DVector<Color> grid_colors[3];
  1895. DVector<Vector3> grid_points[3];
  1896. Vector<Color> origin_colors;
  1897. Vector<Vector3> origin_points;
  1898. for(int i=0;i<3;i++) {
  1899. Vector3 axis;
  1900. axis[i]=1;
  1901. Vector3 axis_n1;
  1902. axis_n1[(i+1)%3]=1;
  1903. Vector3 axis_n2;
  1904. axis_n2[(i+2)%3]=1;
  1905. origin_colors.push_back(Color(axis.x,axis.y,axis.z));
  1906. origin_colors.push_back(Color(axis.x,axis.y,axis.z));
  1907. origin_points.push_back(axis*4096);
  1908. origin_points.push_back(axis*-4096);
  1909. #define ORIGIN_GRID_SIZE 25
  1910. for(int j=-ORIGIN_GRID_SIZE;j<=ORIGIN_GRID_SIZE;j++) {
  1911. grid_colors[i].push_back(Color(axis.x,axis.y,axis.z,0.2));
  1912. grid_colors[i].push_back(Color(axis.x,axis.y,axis.z,0.2));
  1913. grid_colors[i].push_back(Color(axis.x,axis.y,axis.z,0.2));
  1914. grid_colors[i].push_back(Color(axis.x,axis.y,axis.z,0.2));
  1915. grid_points[i].push_back(axis_n1*ORIGIN_GRID_SIZE+axis_n2*j);
  1916. grid_points[i].push_back(-axis_n1*ORIGIN_GRID_SIZE+axis_n2*j);
  1917. grid_points[i].push_back(axis_n2*ORIGIN_GRID_SIZE+axis_n1*j);
  1918. grid_points[i].push_back(-axis_n2*ORIGIN_GRID_SIZE+axis_n1*j);
  1919. }
  1920. grid[i] = VisualServer::get_singleton()->mesh_create();
  1921. Array d;
  1922. d.resize(VS::ARRAY_MAX);
  1923. d[VisualServer::ARRAY_VERTEX]=grid_points[i];
  1924. d[VisualServer::ARRAY_COLOR]=grid_colors[i];
  1925. VisualServer::get_singleton()->mesh_add_surface(grid[i],VisualServer::PRIMITIVE_LINES,d);
  1926. VisualServer::get_singleton()->mesh_surface_set_material(grid[i],0,indicator_mat);
  1927. grid_instance[i] = VisualServer::get_singleton()->instance_create2(grid[i],get_scene()->get_root()->get_world()->get_scenario());
  1928. grid_visible[i]=false;
  1929. grid_enable[i]=false;
  1930. VisualServer::get_singleton()->instance_geometry_set_flag(grid_instance[i],VS::INSTANCE_FLAG_VISIBLE,false);
  1931. VisualServer::get_singleton()->instance_geometry_set_flag(grid_instance[i],VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1932. }
  1933. origin = VisualServer::get_singleton()->mesh_create();
  1934. Array d;
  1935. d.resize(VS::ARRAY_MAX);
  1936. d[VisualServer::ARRAY_VERTEX]=origin_points;
  1937. d[VisualServer::ARRAY_COLOR]=origin_colors;
  1938. VisualServer::get_singleton()->mesh_add_surface(origin,VisualServer::PRIMITIVE_LINES,d);
  1939. VisualServer::get_singleton()->mesh_surface_set_material(origin,0,indicator_mat,true);
  1940. // origin = VisualServer::get_singleton()->poly_create();
  1941. // VisualServer::get_singleton()->poly_add_primitive(origin,origin_points,Vector<Vector3>(),origin_colors,Vector<Vector3>());
  1942. // VisualServer::get_singleton()->poly_set_material(origin,indicator_mat,true);
  1943. origin_instance = VisualServer::get_singleton()->instance_create2(origin,get_scene()->get_root()->get_world()->get_scenario());
  1944. VisualServer::get_singleton()->instance_geometry_set_flag(origin_instance,VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1945. VisualServer::get_singleton()->instance_geometry_set_flag(grid_instance[1],VS::INSTANCE_FLAG_VISIBLE,true);
  1946. grid_enable[1]=true;
  1947. grid_visible[1]=true;
  1948. grid_enabled=true;
  1949. last_grid_snap=1;
  1950. }
  1951. {
  1952. cursor_mesh = VisualServer::get_singleton()->mesh_create();
  1953. DVector<Vector3> cursor_points;
  1954. float cs = 0.25;
  1955. cursor_points.push_back(Vector3(+cs,0,0));
  1956. cursor_points.push_back(Vector3(-cs,0,0));
  1957. cursor_points.push_back(Vector3(0,+cs,0));
  1958. cursor_points.push_back(Vector3(0,-cs,0));
  1959. cursor_points.push_back(Vector3(0,0,+cs));
  1960. cursor_points.push_back(Vector3(0,0,-cs));
  1961. RID cmat=VisualServer::get_singleton()->fixed_material_create();
  1962. VisualServer::get_singleton()->fixed_material_set_param(cmat,VS::FIXED_MATERIAL_PARAM_DIFFUSE,Color(0,1,1));
  1963. VisualServer::get_singleton()->material_set_flag( cmat, VisualServer::MATERIAL_FLAG_UNSHADED, true );
  1964. VisualServer::get_singleton()->fixed_material_set_flag(cmat, VisualServer::FIXED_MATERIAL_FLAG_USE_ALPHA,true);
  1965. VisualServer::get_singleton()->fixed_material_set_flag(cmat, VisualServer::FIXED_MATERIAL_FLAG_USE_COLOR_ARRAY,true);
  1966. Array d;
  1967. d.resize(VS::ARRAY_MAX);
  1968. d[VS::ARRAY_VERTEX]=cursor_points;
  1969. VisualServer::get_singleton()->mesh_add_surface(cursor_mesh,VS::PRIMITIVE_LINES,d);
  1970. VisualServer::get_singleton()->mesh_surface_set_material(cursor_mesh,0,cmat,true);
  1971. cursor_instance = VisualServer::get_singleton()->instance_create2(cursor_mesh,get_scene()->get_root()->get_world()->get_scenario());
  1972. VisualServer::get_singleton()->instance_geometry_set_flag(cursor_instance,VS::INSTANCE_FLAG_CAST_SHADOW,false);
  1973. }
  1974. {
  1975. //move gizmo
  1976. gizmo_hl = Ref<FixedMaterial>( memnew( FixedMaterial ) );
  1977. gizmo_hl->set_flag(Material::FLAG_UNSHADED, true);
  1978. gizmo_hl->set_flag(Material::FLAG_ONTOP, true);
  1979. gizmo_hl->set_fixed_flag(FixedMaterial::FLAG_USE_ALPHA, true);
  1980. gizmo_hl->set_parameter(FixedMaterial::PARAM_DIFFUSE,Color(1,1,1,0.4));
  1981. for(int i=0;i<3;i++) {
  1982. move_gizmo[i]=Ref<Mesh>( memnew( Mesh ) );
  1983. rotate_gizmo[i]=Ref<Mesh>( memnew( Mesh ) );
  1984. Ref<FixedMaterial> mat = memnew( FixedMaterial );
  1985. mat->set_flag(Material::FLAG_UNSHADED, true);
  1986. mat->set_flag(Material::FLAG_ONTOP, true);
  1987. mat->set_fixed_flag(FixedMaterial::FLAG_USE_ALPHA, true);
  1988. Color col;
  1989. col[i]=1.0;
  1990. col.a=0.2;
  1991. mat->set_parameter(FixedMaterial::PARAM_DIFFUSE,col);
  1992. gizmo_color[i]=mat;
  1993. Vector3 ivec;
  1994. ivec[i]=1;
  1995. Vector3 nivec;
  1996. nivec[(i+1)%3]=1;
  1997. nivec[(i+2)%3]=1;
  1998. Vector3 ivec2;
  1999. ivec2[(i+1)%3]=1;
  2000. Vector3 ivec3;
  2001. ivec3[(i+2)%3]=1;
  2002. {
  2003. Ref<SurfaceTool> surftool = memnew( SurfaceTool );
  2004. surftool->begin(Mesh::PRIMITIVE_TRIANGLES);
  2005. //translate
  2006. const int arrow_points=5;
  2007. Vector3 arrow[5]={
  2008. nivec*0.0+ivec*0.0,
  2009. nivec*0.01+ivec*0.0,
  2010. nivec*0.01+ivec*1.0,
  2011. nivec*0.1+ivec*1.0,
  2012. nivec*0.0+ivec*(1+GIZMO_ARROW_SIZE),
  2013. };
  2014. int arrow_sides=6;
  2015. for(int i = 0; i < 7 ; i++) {
  2016. Matrix3 ma(ivec,Math_PI*2*float(i)/arrow_sides);
  2017. Matrix3 mb(ivec,Math_PI*2*float(i+1)/arrow_sides);
  2018. for(int j=0;j<arrow_points-1;j++) {
  2019. Vector3 points[4]={
  2020. ma.xform(arrow[j]),
  2021. mb.xform(arrow[j]),
  2022. mb.xform(arrow[j+1]),
  2023. ma.xform(arrow[j+1]),
  2024. };
  2025. surftool->add_vertex(points[0]);
  2026. surftool->add_vertex(points[1]);
  2027. surftool->add_vertex(points[2]);
  2028. surftool->add_vertex(points[0]);
  2029. surftool->add_vertex(points[2]);
  2030. surftool->add_vertex(points[3]);
  2031. }
  2032. }
  2033. surftool->set_material(mat);
  2034. surftool->commit(move_gizmo[i]);
  2035. }
  2036. {
  2037. Ref<SurfaceTool> surftool = memnew( SurfaceTool );
  2038. surftool->begin(Mesh::PRIMITIVE_TRIANGLES);
  2039. Vector3 circle[5]={
  2040. ivec*0.02+ivec2*0.02+ivec2*1.0,
  2041. ivec*-0.02+ivec2*0.02+ivec2*1.0,
  2042. ivec*-0.02+ivec2*-0.02+ivec2*1.0,
  2043. ivec*0.02+ivec2*-0.02+ivec2*1.0,
  2044. ivec*0.02+ivec2*0.02+ivec2*1.0,
  2045. };
  2046. for(int k = 0; k < 33 ; k++) {
  2047. Matrix3 ma(ivec,Math_PI*2*float(k)/32);
  2048. Matrix3 mb(ivec,Math_PI*2*float(k+1)/32);
  2049. for(int j=0;j<4;j++) {
  2050. Vector3 points[4]={
  2051. ma.xform(circle[j]),
  2052. mb.xform(circle[j]),
  2053. mb.xform(circle[j+1]),
  2054. ma.xform(circle[j+1]),
  2055. };
  2056. surftool->add_vertex(points[0]);
  2057. surftool->add_vertex(points[1]);
  2058. surftool->add_vertex(points[2]);
  2059. surftool->add_vertex(points[0]);
  2060. surftool->add_vertex(points[2]);
  2061. surftool->add_vertex(points[3]);
  2062. }
  2063. }
  2064. surftool->set_material(mat);
  2065. surftool->commit(rotate_gizmo[i]);
  2066. }
  2067. }
  2068. }
  2069. /*for(int i=0;i<4;i++) {
  2070. viewports[i]->init_gizmo_instance(i);
  2071. }*/
  2072. _generate_selection_box();
  2073. //get_scene()->get_root_node()->cast_to<EditorNode>()->get_scene_root()->add_child(camera);
  2074. //current_camera=camera;
  2075. }
  2076. void SpatialEditor::_finish_indicators() {
  2077. VisualServer::get_singleton()->free(origin_instance);
  2078. VisualServer::get_singleton()->free(origin);
  2079. for(int i=0;i<3;i++) {
  2080. VisualServer::get_singleton()->free(grid_instance[i]);
  2081. VisualServer::get_singleton()->free(grid[i]);
  2082. }
  2083. VisualServer::get_singleton()->free(light_instance);
  2084. VisualServer::get_singleton()->free(light);
  2085. //VisualServer::get_singleton()->free(poly);
  2086. //VisualServer::get_singleton()->free(indicators_instance);
  2087. //VisualServer::get_singleton()->free(indicators);
  2088. VisualServer::get_singleton()->free(cursor_instance);
  2089. VisualServer::get_singleton()->free(cursor_mesh);
  2090. }
  2091. void SpatialEditor::_instance_scene() {
  2092. #if 0
  2093. EditorNode *en = get_scene()->get_root_node()->cast_to<EditorNode>();
  2094. ERR_FAIL_COND(!en);
  2095. String path = en->get_scenes_dock()->get_selected_path();
  2096. if (path=="") {
  2097. set_message("No scene selected to instance!");
  2098. return;
  2099. }
  2100. undo_redo->create_action("Instance at Cursor");
  2101. Node* scene = en->request_instance_scene(path);
  2102. if (!scene) {
  2103. set_message("Could not instance scene!");
  2104. undo_redo->commit_action(); //bleh
  2105. return;
  2106. }
  2107. Spatial *s = scene->cast_to<Spatial>();
  2108. if (s) {
  2109. undo_redo->add_do_method(s,"set_global_transform",Transform(Matrix3(),cursor.cursor_pos));
  2110. }
  2111. undo_redo->commit_action();
  2112. #endif
  2113. }
  2114. /*
  2115. void SpatialEditor::_update_selection() {
  2116. }
  2117. */
  2118. void SpatialEditor::_unhandled_key_input(InputEvent p_event) {
  2119. if (!is_visible())
  2120. return;
  2121. {
  2122. EditorNode *en = editor;
  2123. EditorPlugin *over_plugin = en->get_editor_plugin_over();
  2124. if (over_plugin && over_plugin->forward_input_event(p_event)) {
  2125. return; //ate the over input event
  2126. }
  2127. }
  2128. switch(p_event.type) {
  2129. case InputEvent::KEY: {
  2130. const InputEventKey &k=p_event.key;
  2131. if (!k.pressed)
  2132. break;
  2133. switch(k.scancode) {
  2134. case KEY_Q: _menu_item_pressed(MENU_TOOL_SELECT); break;
  2135. case KEY_W: _menu_item_pressed(MENU_TOOL_MOVE); break;
  2136. case KEY_E: _menu_item_pressed(MENU_TOOL_ROTATE); break;
  2137. case KEY_R: _menu_item_pressed(MENU_TOOL_SCALE); break;
  2138. #if 0
  2139. #endif
  2140. }
  2141. } break;
  2142. }
  2143. }
  2144. void SpatialEditor::_notification(int p_what) {
  2145. if (p_what==NOTIFICATION_READY) {
  2146. tool_button[SpatialEditor::TOOL_MODE_SELECT]->set_icon( get_icon("ToolSelect","EditorIcons") );
  2147. tool_button[SpatialEditor::TOOL_MODE_MOVE]->set_icon( get_icon("ToolMove","EditorIcons") );
  2148. tool_button[SpatialEditor::TOOL_MODE_ROTATE]->set_icon( get_icon("ToolRotate","EditorIcons") );
  2149. tool_button[SpatialEditor::TOOL_MODE_SCALE]->set_icon( get_icon("ToolScale","EditorIcons") );
  2150. instance_button->set_icon( get_icon("SpatialAdd","EditorIcons") );
  2151. view_menu->get_popup()->set_item_icon(view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT),get_icon("Panels1","EditorIcons"));
  2152. view_menu->get_popup()->set_item_icon(view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS),get_icon("Panels2","EditorIcons"));
  2153. view_menu->get_popup()->set_item_icon(view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS),get_icon("Panels3","EditorIcons"));
  2154. view_menu->get_popup()->set_item_icon(view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS),get_icon("Panels4","EditorIcons"));
  2155. _menu_item_pressed(MENU_VIEW_USE_1_VIEWPORT);
  2156. get_scene()->connect("node_removed",this,"_node_removed");
  2157. }
  2158. if (p_what==NOTIFICATION_ENTER_SCENE) {
  2159. gizmos = memnew( SpatialEditorGizmos );
  2160. _init_indicators();
  2161. }
  2162. if (p_what==NOTIFICATION_EXIT_SCENE) {
  2163. _finish_indicators();
  2164. memdelete( gizmos );
  2165. }
  2166. }
  2167. void SpatialEditor::add_control_to_menu_panel(Control *p_control) {
  2168. hbc_menu->add_child(p_control);
  2169. }
  2170. void SpatialEditor::set_can_preview(Camera* p_preview) {
  2171. for(int i=0;i<4;i++) {
  2172. viewports[i]->set_can_preview(p_preview);
  2173. }
  2174. }
  2175. VSplitContainer *SpatialEditor::get_shader_split() {
  2176. return shader_split;
  2177. }
  2178. HSplitContainer *SpatialEditor::get_palette_split() {
  2179. return palette_split;
  2180. }
  2181. void SpatialEditor::_request_gizmo(Object* p_obj) {
  2182. Spatial *sp=p_obj->cast_to<Spatial>();
  2183. if (!sp)
  2184. return;
  2185. if (editor->get_edited_scene() && (sp==editor->get_edited_scene() || sp->get_owner()==editor->get_edited_scene())) {
  2186. Ref<SpatialEditorGizmo> seg = gizmos->get_gizmo(sp);
  2187. if (seg.is_valid()) {
  2188. sp->set_gizmo(seg);
  2189. }
  2190. for (List<EditorPlugin*>::Element *E=gizmo_plugins.front();E;E=E->next()) {
  2191. if (E->get()->create_spatial_gizmo(sp)) {
  2192. seg = sp->get_gizmo();
  2193. if (sp==selected && seg.is_valid()) {
  2194. seg->set_selected(true);
  2195. selected->update_gizmo();
  2196. }
  2197. return;
  2198. }
  2199. }
  2200. if (seg.is_valid() && sp==selected) {
  2201. seg->set_selected(true);
  2202. selected->update_gizmo();
  2203. }
  2204. }
  2205. }
  2206. void SpatialEditor::_toggle_maximize_view(Object* p_viewport) {
  2207. if (!p_viewport) return;
  2208. SpatialEditorViewport *current_viewport = p_viewport->cast_to<SpatialEditorViewport>();
  2209. if (!current_viewport) return;
  2210. int index=-1;
  2211. bool maximized = false;
  2212. for(int i=0;i<4;i++) {
  2213. if (viewports[i]==current_viewport) {
  2214. index=i;
  2215. if ( current_viewport->get_global_rect() == viewport_base->get_global_rect() )
  2216. maximized=true;
  2217. break;
  2218. }
  2219. }
  2220. if (index==-1) return;
  2221. if (!maximized) {
  2222. for(int i=0;i<4;i++) {
  2223. if (i==index)
  2224. viewports[i]->set_area_as_parent_rect();
  2225. else
  2226. viewports[i]->hide();
  2227. }
  2228. } else {
  2229. for(int i=0;i<4;i++)
  2230. viewports[i]->show();
  2231. if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_1_VIEWPORT) ))
  2232. _menu_item_pressed(MENU_VIEW_USE_1_VIEWPORT);
  2233. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_2_VIEWPORTS) ))
  2234. _menu_item_pressed(MENU_VIEW_USE_2_VIEWPORTS);
  2235. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_3_VIEWPORTS) ))
  2236. _menu_item_pressed(MENU_VIEW_USE_3_VIEWPORTS);
  2237. else if (view_menu->get_popup()->is_item_checked( view_menu->get_popup()->get_item_index(MENU_VIEW_USE_4_VIEWPORTS) ))
  2238. _menu_item_pressed(MENU_VIEW_USE_4_VIEWPORTS);
  2239. }
  2240. }
  2241. void SpatialEditor::_node_removed(Node* p_node) {
  2242. if (p_node==selected)
  2243. selected=NULL;
  2244. }
  2245. void SpatialEditor::_bind_methods() {
  2246. // ObjectTypeDB::bind_method("_input_event",&SpatialEditor::_input_event);
  2247. ObjectTypeDB::bind_method("_unhandled_key_input",&SpatialEditor::_unhandled_key_input);
  2248. ObjectTypeDB::bind_method("_node_removed",&SpatialEditor::_node_removed);
  2249. ObjectTypeDB::bind_method("_menu_item_pressed",&SpatialEditor::_menu_item_pressed);
  2250. ObjectTypeDB::bind_method("_xform_dialog_action",&SpatialEditor::_xform_dialog_action);
  2251. ObjectTypeDB::bind_method("_instance_scene",&SpatialEditor::_instance_scene);
  2252. // ObjectTypeDB::bind_method("_update_selection",&SpatialEditor::_update_selection);
  2253. ObjectTypeDB::bind_method("_get_editor_data",&SpatialEditor::_get_editor_data);
  2254. ObjectTypeDB::bind_method("_request_gizmo",&SpatialEditor::_request_gizmo);
  2255. ObjectTypeDB::bind_method("_toggle_maximize_view",&SpatialEditor::_toggle_maximize_view);
  2256. ADD_SIGNAL( MethodInfo("transform_key_request") );
  2257. }
  2258. SpatialEditor::SpatialEditor(EditorNode *p_editor) {
  2259. viewport_environment = Ref<Environment>( memnew( Environment ) );
  2260. undo_redo=p_editor->get_undo_redo();
  2261. VBoxContainer *vbc = this;
  2262. custom_camera=NULL;
  2263. singleton=this;
  2264. editor=p_editor;
  2265. editor_selection=editor->get_editor_selection();
  2266. editor_selection->add_editor_plugin(this);
  2267. editor_selection->connect("selection_changed",this,"_update_selection");
  2268. snap_enabled=false;
  2269. tool_mode = TOOL_MODE_SELECT;
  2270. //set_focus_mode(FOCUS_ALL);
  2271. hbc_menu = memnew( HBoxContainer );
  2272. vbc->add_child(hbc_menu);
  2273. Vector<Variant> button_binds;
  2274. button_binds.resize(1);
  2275. tool_button[TOOL_MODE_SELECT] = memnew( ToolButton );
  2276. hbc_menu->add_child( tool_button[TOOL_MODE_SELECT] );
  2277. tool_button[TOOL_MODE_SELECT]->set_toggle_mode(true);
  2278. tool_button[TOOL_MODE_SELECT]->set_flat(true);
  2279. tool_button[TOOL_MODE_SELECT]->set_pressed(true);
  2280. button_binds[0]=MENU_TOOL_SELECT;
  2281. tool_button[TOOL_MODE_SELECT]->connect("pressed", this,"_menu_item_pressed",button_binds);
  2282. tool_button[TOOL_MODE_SELECT]->set_tooltip("Select Mode (Q)");
  2283. tool_button[TOOL_MODE_MOVE] = memnew( ToolButton );
  2284. hbc_menu->add_child( tool_button[TOOL_MODE_MOVE] );
  2285. tool_button[TOOL_MODE_MOVE]->set_toggle_mode(true);
  2286. tool_button[TOOL_MODE_MOVE]->set_flat(true);
  2287. button_binds[0]=MENU_TOOL_MOVE;
  2288. tool_button[TOOL_MODE_MOVE]->connect("pressed", this,"_menu_item_pressed",button_binds);
  2289. tool_button[TOOL_MODE_MOVE]->set_tooltip("Move Mode (W)");
  2290. tool_button[TOOL_MODE_ROTATE] = memnew( ToolButton );
  2291. hbc_menu->add_child( tool_button[TOOL_MODE_ROTATE] );
  2292. tool_button[TOOL_MODE_ROTATE]->set_toggle_mode(true);
  2293. tool_button[TOOL_MODE_ROTATE]->set_flat(true);
  2294. button_binds[0]=MENU_TOOL_ROTATE;
  2295. tool_button[TOOL_MODE_ROTATE]->connect("pressed", this,"_menu_item_pressed",button_binds);
  2296. tool_button[TOOL_MODE_ROTATE]->set_tooltip("Rotate Mode (E)");
  2297. tool_button[TOOL_MODE_SCALE] = memnew( ToolButton );
  2298. hbc_menu->add_child( tool_button[TOOL_MODE_SCALE] );
  2299. tool_button[TOOL_MODE_SCALE]->set_toggle_mode(true);
  2300. tool_button[TOOL_MODE_SCALE]->set_flat(true);
  2301. button_binds[0]=MENU_TOOL_SCALE;
  2302. tool_button[TOOL_MODE_SCALE]->connect("pressed", this,"_menu_item_pressed",button_binds);
  2303. tool_button[TOOL_MODE_SCALE]->set_tooltip("Scale Mode (R)");
  2304. instance_button = memnew( Button );
  2305. hbc_menu->add_child( instance_button );
  2306. instance_button->set_flat(true);
  2307. instance_button->connect("pressed",this,"_instance_scene");
  2308. VSeparator *vs = memnew( VSeparator );
  2309. hbc_menu->add_child(vs);
  2310. PopupMenu *p;
  2311. transform_menu = memnew( MenuButton );
  2312. transform_menu->set_text("Transform");
  2313. hbc_menu->add_child( transform_menu );
  2314. p = transform_menu->get_popup();
  2315. p->add_check_item("Use Snap",MENU_TRANSFORM_USE_SNAP);
  2316. p->add_item("Configure Snap..",MENU_TRANSFORM_CONFIGURE_SNAP);
  2317. p->add_separator();
  2318. p->add_check_item("Local Coords",MENU_TRANSFORM_LOCAL_COORDS);
  2319. //p->set_item_checked(p->get_item_count()-1,true);
  2320. p->add_separator();
  2321. p->add_item("Transform Dialog..",MENU_TRANSFORM_DIALOG);
  2322. p->connect("item_pressed", this,"_menu_item_pressed");
  2323. view_menu = memnew( MenuButton );
  2324. view_menu->set_text("View");
  2325. view_menu->set_pos( Point2( 212,0) );
  2326. hbc_menu->add_child( view_menu );
  2327. p = view_menu->get_popup();
  2328. p->add_check_item("Use Default Light",MENU_VIEW_USE_DEFAULT_LIGHT);
  2329. p->add_separator();
  2330. p->add_check_item("1 Viewport",MENU_VIEW_USE_1_VIEWPORT,KEY_MASK_ALT+KEY_1);
  2331. p->add_check_item("2 Viewports",MENU_VIEW_USE_2_VIEWPORTS,KEY_MASK_ALT+KEY_2);
  2332. p->add_check_item("3 Viewports",MENU_VIEW_USE_3_VIEWPORTS,KEY_MASK_ALT+KEY_3);
  2333. p->add_check_item("4 Viewports",MENU_VIEW_USE_4_VIEWPORTS,KEY_MASK_ALT+KEY_4);
  2334. p->add_separator();
  2335. p->add_check_item("Display Normal",MENU_VIEW_DISPLAY_NORMAL);
  2336. p->add_check_item("Display Wireframe",MENU_VIEW_DISPLAY_WIREFRAME);
  2337. p->add_check_item("Display Overdraw",MENU_VIEW_DISPLAY_OVERDRAW);
  2338. p->add_separator();
  2339. p->add_check_item("View Origin",MENU_VIEW_ORIGIN);
  2340. p->add_check_item("View Grid",MENU_VIEW_GRID);
  2341. p->add_separator();
  2342. p->add_check_item("Settings",MENU_VIEW_CAMERA_SETTINGS );
  2343. p->set_item_checked( p->get_item_index(MENU_VIEW_USE_DEFAULT_LIGHT), true );
  2344. p->set_item_checked( p->get_item_index(MENU_VIEW_DISPLAY_NORMAL), true );
  2345. p->set_item_checked( p->get_item_index(MENU_VIEW_ORIGIN), true );
  2346. p->set_item_checked( p->get_item_index(MENU_VIEW_GRID), true );
  2347. p->connect("item_pressed", this,"_menu_item_pressed");
  2348. /* REST OF MENU */
  2349. palette_split = memnew( HSplitContainer);
  2350. palette_split->set_v_size_flags(SIZE_EXPAND_FILL);
  2351. vbc->add_child(palette_split);
  2352. shader_split = memnew( VSplitContainer );
  2353. shader_split->set_h_size_flags(SIZE_EXPAND_FILL);
  2354. palette_split->add_child(shader_split);
  2355. viewport_base = memnew( Control );
  2356. shader_split->add_child(viewport_base);
  2357. viewport_base->set_v_size_flags(SIZE_EXPAND_FILL);
  2358. for(int i=0;i<4;i++) {
  2359. viewports[i] = memnew( SpatialEditorViewport(this,editor,i) );
  2360. viewports[i]->connect("toggle_maximize_view",this,"_toggle_maximize_view");
  2361. viewport_base->add_child(viewports[i]);
  2362. }
  2363. //vbc->add_child(viewport_base);
  2364. /* SNAP DIALOG */
  2365. snap_dialog = memnew( ConfirmationDialog );
  2366. snap_dialog->set_title("Snap Settings");
  2367. add_child(snap_dialog);
  2368. Label *l = memnew(Label);
  2369. l->set_text("Translate Snap:");
  2370. l->set_pos(Point2(5,5));
  2371. snap_dialog->add_child(l);
  2372. snap_translate = memnew( LineEdit );
  2373. snap_translate->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2374. snap_translate->set_begin( Point2(15,22) );
  2375. snap_translate->set_end( Point2(15,35) );
  2376. snap_translate->set_text("1");
  2377. snap_dialog->add_child(snap_translate);
  2378. l = memnew(Label);
  2379. l->set_text("Rotate Snap (deg.):");
  2380. l->set_pos(Point2(5,45));
  2381. snap_dialog->add_child(l);
  2382. snap_rotate = memnew( LineEdit );
  2383. snap_rotate->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2384. snap_rotate->set_begin( Point2(15,62) );
  2385. snap_rotate->set_end( Point2(15,75) );
  2386. snap_rotate->set_text("5");
  2387. snap_dialog->add_child(snap_rotate);
  2388. l = memnew(Label);
  2389. l->set_text("Scale Snap (%):");
  2390. l->set_pos(Point2(5,85));
  2391. snap_dialog->add_child(l);
  2392. snap_scale = memnew( LineEdit );
  2393. snap_scale->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2394. snap_scale->set_begin( Point2(15,102) );
  2395. snap_scale->set_end( Point2(15,115) );
  2396. snap_scale->set_text("5");
  2397. snap_dialog->add_child(snap_scale);
  2398. //snap_dialog->get_cancel()->hide();
  2399. /* SNAP DIALOG */
  2400. settings_dialog = memnew( ConfirmationDialog );
  2401. settings_dialog->set_title("Viewport Settings");
  2402. add_child(settings_dialog);
  2403. l = memnew(Label);
  2404. l->set_text("Perspective FOV (deg.):");
  2405. l->set_pos(Point2(5,5));
  2406. settings_dialog->add_child(l);
  2407. settings_fov = memnew( LineEdit );
  2408. settings_fov->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2409. settings_fov->set_begin( Point2(15,22) );
  2410. settings_fov->set_end( Point2(15,35) );
  2411. settings_fov->set_text(EDITOR_DEF("3d_editor/default_fov",60.0));
  2412. settings_dialog->add_child(settings_fov);
  2413. l = memnew(Label);
  2414. l->set_text("View Z-Near");
  2415. l->set_pos(Point2(5,45));
  2416. settings_dialog->add_child(l);
  2417. settings_znear = memnew( LineEdit );
  2418. settings_znear->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2419. settings_znear->set_begin( Point2(15,62) );
  2420. settings_znear->set_end( Point2(15,75) );
  2421. settings_znear->set_text(EDITOR_DEF("3d_editor/default_z_near",0.1));
  2422. settings_dialog->add_child(settings_znear);
  2423. l = memnew(Label);
  2424. l->set_text("View Z-Far");
  2425. l->set_pos(Point2(5,85));
  2426. settings_dialog->add_child(l);
  2427. settings_zfar = memnew( LineEdit );
  2428. settings_zfar->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2429. settings_zfar->set_begin( Point2(15,102) );
  2430. settings_zfar->set_end( Point2(15,115) );
  2431. settings_zfar->set_text(EDITOR_DEF("3d_editor/default_z_far",500.0));
  2432. settings_dialog->add_child(settings_zfar);
  2433. //settings_dialog->get_cancel()->hide();
  2434. /* XFORM DIALOG */
  2435. xform_dialog = memnew( ConfirmationDialog );
  2436. xform_dialog->set_title("Transform Change");
  2437. add_child(xform_dialog);
  2438. l = memnew(Label);
  2439. l->set_text("Translate:");
  2440. l->set_pos(Point2(5,5));
  2441. xform_dialog->add_child(l);
  2442. for(int i=0;i<3;i++) {
  2443. xform_translate[i] = memnew( LineEdit );
  2444. xform_translate[i]->set_pos( Point2(15+i*60,22) );
  2445. xform_translate[i]->set_size( Size2(50,12 ) );
  2446. xform_dialog->add_child( xform_translate[i] );
  2447. }
  2448. l = memnew(Label);
  2449. l->set_text("Rotate (deg.):");
  2450. l->set_pos(Point2(5,45));
  2451. xform_dialog->add_child(l);
  2452. for(int i=0;i<3;i++) {
  2453. xform_rotate[i] = memnew( LineEdit );
  2454. xform_rotate[i]->set_pos( Point2(15+i*60,62) );
  2455. xform_rotate[i]->set_size( Size2(50,22 ) );
  2456. xform_dialog->add_child(xform_rotate[i]);
  2457. }
  2458. l = memnew(Label);
  2459. l->set_text("Scale (ratio):");
  2460. l->set_pos(Point2(5,85));
  2461. xform_dialog->add_child(l);
  2462. for(int i=0;i<3;i++) {
  2463. xform_scale[i] = memnew( LineEdit );
  2464. xform_scale[i]->set_pos( Point2(15+i*60,102) );
  2465. xform_scale[i]->set_size( Size2(50,22 ) );
  2466. xform_dialog->add_child(xform_scale[i]);
  2467. }
  2468. l = memnew(Label);
  2469. l->set_text("Transform Type");
  2470. l->set_pos(Point2(5,125));
  2471. xform_dialog->add_child(l);
  2472. xform_type = memnew( OptionButton );
  2473. xform_type->set_anchor( MARGIN_RIGHT, ANCHOR_END );
  2474. xform_type->set_begin( Point2(15,142) );
  2475. xform_type->set_end( Point2(15,75) );
  2476. xform_type->add_item("Pre");
  2477. xform_type->add_item("Post");
  2478. xform_dialog->add_child(xform_type);
  2479. xform_dialog->connect("confirmed", this,"_xform_dialog_action");
  2480. scenario_debug=VisualServer::SCENARIO_DEBUG_DISABLED;
  2481. selected=NULL;
  2482. set_process_unhandled_key_input(true);
  2483. add_to_group("_spatial_editor_group");
  2484. EDITOR_DEF("3d_editor/manipulator_gizmo_size",80);
  2485. EditorSettings::get_singleton()->add_property_hint(PropertyInfo(Variant::INT,"3d_editor/manipulator_gizmo_size",PROPERTY_HINT_RANGE,"16,1024,1"));
  2486. over_gizmo_handle=-1;
  2487. }
  2488. SpatialEditor::~SpatialEditor() {
  2489. }
  2490. void SpatialEditorPlugin::make_visible(bool p_visible) {
  2491. if (p_visible) {
  2492. spatial_editor->show();
  2493. spatial_editor->set_process(true);
  2494. //VisualServer::get_singleton()->viewport_set_hide_scenario(editor->get_scene_root()->get_viewport(),false);
  2495. spatial_editor->grab_focus();
  2496. } else {
  2497. spatial_editor->hide();
  2498. spatial_editor->set_process(false);
  2499. //VisualServer::get_singleton()->viewport_set_hide_scenario(editor->get_scene_root()->get_viewport(),true);
  2500. }
  2501. }
  2502. void SpatialEditorPlugin::edit(Object *p_object) {
  2503. spatial_editor->edit(p_object->cast_to<Spatial>());
  2504. }
  2505. bool SpatialEditorPlugin::handles(Object *p_object) const {
  2506. return p_object->is_type("Spatial");
  2507. }
  2508. Dictionary SpatialEditorPlugin::get_state() const {
  2509. return spatial_editor->get_state();
  2510. }
  2511. void SpatialEditorPlugin::set_state(const Dictionary& p_state) {
  2512. spatial_editor->set_state(p_state);
  2513. }
  2514. void SpatialEditor::snap_cursor_to_plane(const Plane& p_plane) {
  2515. // cursor.pos=p_plane.project(cursor.pos);
  2516. }
  2517. void SpatialEditorPlugin::_bind_methods() {
  2518. ObjectTypeDB::bind_method("snap_cursor_to_plane",&SpatialEditorPlugin::snap_cursor_to_plane);
  2519. }
  2520. void SpatialEditorPlugin::snap_cursor_to_plane(const Plane& p_plane) {
  2521. spatial_editor->snap_cursor_to_plane(p_plane);
  2522. }
  2523. SpatialEditorPlugin::SpatialEditorPlugin(EditorNode *p_node) {
  2524. editor=p_node;
  2525. spatial_editor = memnew( SpatialEditor(p_node) );
  2526. editor->get_viewport()->add_child(spatial_editor);
  2527. spatial_editor->set_area_as_parent_rect();
  2528. spatial_editor->hide();
  2529. spatial_editor->connect("transform_key_request",editor,"_transform_keyed");
  2530. //spatial_editor->set_process(true);
  2531. }
  2532. SpatialEditorPlugin::~SpatialEditorPlugin() {
  2533. }