| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791 |
- /*
- Copyright (C) 2012 by Ivan Safrin
-
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
-
- The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.
-
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.
- */
- #include "PolycodeFrame.h"
- UIColorPicker *globalColorPicker;
- PolycodeFrame *globalFrame;
- extern UIGlobalMenu *globalMenu;
- EditorHolder *activeEditorHolder = NULL;
- extern PolycodeEditorManager *globalEditorManager;
- EditPoint::EditPoint(BezierPoint *point, unsigned int type) : Entity() {
- this->point = point;
- this->type = type;
- processInputEvents = true;
-
- draggingPoint = NULL;
- dragging = false;
- controlHandle1 = new UIRect(5, 5);
- controlHandle1->setColor(0.0, 1.0, 0.3, 1.0);
- controlHandle1->setAnchorPoint(0.0, 0.0, 0.0);
-
- controlHandle1->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
- controlHandle1->addEventListener(this, InputEvent::EVENT_MOUSEUP);
- controlHandle1->addEventListener(this, InputEvent::EVENT_MOUSEUP_OUTSIDE);
- controlHandle1->processInputEvents = true;
- controlHandle1->setWidth(30);
- controlHandle1->setHeight(30);
-
- addChild(controlHandle1);
-
- controlHandle2 = new UIRect(5, 5);
- controlHandle2->setColor(0.0, 1.0, 0.3, 1.0);
- controlHandle2->setAnchorPoint(0.0, 0.0, 0.0);
- controlHandle2->processInputEvents = true;
-
- controlHandle2->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
- controlHandle2->addEventListener(this, InputEvent::EVENT_MOUSEUP);
- controlHandle2->addEventListener(this, InputEvent::EVENT_MOUSEUP_OUTSIDE);
- controlHandle2->setWidth(30);
- controlHandle2->setHeight(30);
-
- addChild(controlHandle2);
-
- pointHandle = new UIRect(8, 8);
- pointHandle->setColor(1.0, 0.5, 0.2, 1.0);
- pointHandle->processInputEvents = true;
- pointHandle->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
- pointHandle->addEventListener(this, InputEvent::EVENT_MOUSEUP);
- pointHandle->addEventListener(this, InputEvent::EVENT_MOUSEUP_OUTSIDE);
- pointHandle->setAnchorPoint(0.0, 0.0, 0.0);
- pointHandle->setWidth(30);
- pointHandle->setHeight(30);
-
- if(type == TYPE_START_POINT) {
- controlHandle1->visible = false;
- controlHandle1->enabled = false;
- connectorLine1 = NULL;
- } else {
- connectorLine1 = new SceneLine(pointHandle, controlHandle1);
- addChild(connectorLine1);
- connectorLine1->setColorInt(39, 212, 255, 100);
- connectorLine1->setLineWidth(2.0);
- connectorLine1->lineSmooth = true;
- }
-
-
- if(type == TYPE_END_POINT) {
- controlHandle2->visible = false;
- controlHandle2->enabled = false;
- connectorLine2 = NULL;
- } else {
- connectorLine2 = new SceneLine(pointHandle, controlHandle2);
- addChild(connectorLine2);
- connectorLine2->setColorInt(39, 212, 255, 100);
- connectorLine2->setLineWidth(2.0);
- connectorLine2->lineSmooth = true;
- }
-
- CoreServices::getInstance()->getCore()->getInput()->addEventListener(this, InputEvent::EVENT_MOUSEMOVE);
-
- addChild(pointHandle);
-
- updatePosition();
- }
- void EditPoint::setMode(unsigned int mode) {
- this->mode = mode;
- }
- void EditPoint::updateCurvePoint() {
- point->p1.x = controlHandle1->getPosition2D().x/300;
- point->p1.y = controlHandle1->getPosition2D().y/-100;
- point->p2.x = pointHandle->getPosition2D().x/300;
- point->p2.y = pointHandle->getPosition2D().y/-100;
-
- point->p3.x = controlHandle2->getPosition2D().x/300;
- point->p3.y = controlHandle2->getPosition2D().y/-100;
- }
- void EditPoint::handleEvent(Event *event) {
- if(event->getDispatcher() == CoreServices::getInstance()->getCore()->getInput()) {
- switch(event->getEventCode()) {
- case InputEvent::EVENT_MOUSEMOVE:
- if(dragging) {
- if(draggingPoint) {
-
- Vector2 newPosition = CoreServices::getInstance()->getCore()->getInput()->getMousePosition();
-
- Vector2 translateAmt = Vector2(basePosition.x - newPosition.x, basePosition.y - newPosition.y);
-
- if(type != TYPE_POINT && draggingPoint == pointHandle) {
- // don't let drag start and end control points
- translateAmt.x = 0.0;
- }
-
- draggingPoint->setPosition(basePointPosition.x - translateAmt.x, basePointPosition.y - translateAmt.y);
-
- if(draggingPoint == pointHandle) {
- controlHandle1->setPosition(baseControl1.x - translateAmt.x, baseControl1.y - translateAmt.y);
- controlHandle2->setPosition(baseControl2.x - translateAmt.x, baseControl2.y - translateAmt.y);
- }
-
- limitPoint(pointHandle);
- limitPoint(controlHandle1);
- limitPoint(controlHandle2);
-
- updateCurvePoint();
- dispatchEvent(new Event(), Event::CHANGE_EVENT);
- }
- }
- break;
- }
- }
- if(event->getDispatcher() == pointHandle || event->getDispatcher() == controlHandle1 || event->getDispatcher() == controlHandle2) {
- switch(event->getEventCode()) {
- case InputEvent::EVENT_MOUSEDOWN:
- if(mode == CurveEditor::MODE_SELECT) {
- draggingPoint = (UIImage*)event->getDispatcher();
- dragging = true;
- basePosition = CoreServices::getInstance()->getCore()->getInput()->getMousePosition();
- basePointPosition = draggingPoint->getPosition2D();
-
- baseControl1 = controlHandle1->getPosition2D();
- baseControl2 = controlHandle2->getPosition2D();
- }
-
- if(mode == CurveEditor::MODE_REMOVE) {
- if(type == TYPE_POINT) {
- dispatchEvent(new Event(), Event::CANCEL_EVENT);
- }
- }
-
- break;
- case InputEvent::EVENT_MOUSEUP:
- case InputEvent::EVENT_MOUSEUP_OUTSIDE:
- dragging = false;
- draggingPoint = NULL;
- break;
- }
- }
- }
- void EditPoint::limitPoint(UIRect *point) {
- if(point->getPosition().x < 0.0)
- point->setPositionX(0.0);
- if(point->getPosition().x > 300.0)
- point->setPositionX(300.0);
- if(point->getPosition().y > 0.0)
- point->setPositionY(0.0);
- if(point->getPosition().y < -100.0)
- point->setPositionY(-100.0);
- }
- void EditPoint::updatePosition() {
- pointHandle->setPosition(300.0*point->p2.x, -100*point->p2.y, 0.0);
- controlHandle1->setPosition(300.0*point->p1.x, -100*point->p1.y, 0.0);
- controlHandle2->setPosition(300.0*point->p3.x, -100*point->p3.y, 0.0);
- }
- EditPoint::~EditPoint() {
- }
- EditCurve::EditCurve(BezierCurve *targetCurve, Color curveColor) : UIElement() {
-
- this->targetCurve = targetCurve;
-
- visMesh = new SceneMesh(Mesh::LINE_STRIP_MESH);
-
- for(int i=0; i < CURVE_SIZE; i++) {
- visMesh->getMesh()->addVertex(0.0, 0.0, 0.0);
- }
-
- visMesh->lineSmooth = true;
- visMesh->lineWidth = 2.0;
- addChild(visMesh);
- visMesh->setPosition(0, 100);
- visMesh->color = curveColor;
-
- pointsBase = new UIElement();
- addChild(pointsBase);
-
- pointToRemove = NULL;
-
- updateCurve();
- updatePoints();
-
- Deactivate();
- }
- void EditCurve::updatePoints() {
- for(int i=0; i < points.size(); i++) {
- pointsBase->removeChild(points[i]);
- //delete points[i];
- }
-
- points.clear();
- for(int i=0; i < targetCurve->getNumControlPoints(); i++) {
-
- unsigned int type = EditPoint::TYPE_POINT;
- if(i == 0)
- type = EditPoint::TYPE_START_POINT;
- if(i == targetCurve->getNumControlPoints()-1)
- type = EditPoint::TYPE_END_POINT;
- EditPoint *point = new EditPoint(targetCurve->getControlPoint(i), type);
- point->setMode(mode);
- point->addEventListener(this, Event::CHANGE_EVENT);
- point->addEventListener(this, Event::CANCEL_EVENT);
- pointsBase->addChild(point);
- points.push_back(point);
- point->setPosition(0, 100);
- }
- }
- void EditCurve::setMode(unsigned int mode) {
- this->mode = mode;
- for(int i=0; i < points.size(); i++) {
- points[i]->setMode(mode);
- }
- }
- void EditCurve::Activate() {
- pointsBase->visible = true;
- pointsBase->enabled = true;
- visMesh->color.a = 1.0;
- }
- void EditCurve::Deactivate() {
- pointsBase->visible = false;
- pointsBase->enabled = false;
- visMesh->color.a = 1.0;
- }
- void EditCurve::Update() {
- if(pointToRemove) {
- targetCurve->removePoint(pointToRemove->point);
- updatePoints();
- updateCurve();
- pointToRemove = NULL;
- }
- }
- void EditCurve::handleEvent(Event *event) {
- if(event->getEventCode() == Event::CHANGE_EVENT) {
- updateCurve();
- }
- if(event->getEventCode() == Event::CANCEL_EVENT) {
- for(int i=0; i < points.size(); i++) {
- if(event->getDispatcher() == points[i]) {
- pointToRemove = points[i];
- break;
- }
- }
- }
- }
- void EditCurve::updateCurve() {
- targetCurve->recalculateDistances();
- targetCurve->rebuildBuffers();
-
- Number interval = 300.0/CURVE_SIZE;
- Number normInterval = 1.0/CURVE_SIZE;
-
- interval += interval/CURVE_SIZE;
- normInterval += normInterval/CURVE_SIZE;
-
- for(int i=0; i < CURVE_SIZE; i++) {
- visMesh->getMesh()->getVertex(i)->set(targetCurve->getPointAt(normInterval * i).x * 300, targetCurve->getPointAt(normInterval * i).y * 100.0, 0.0);
- }
-
- visMesh->getMesh()->arrayDirtyMap[RenderDataArray::VERTEX_DATA_ARRAY] = true;
- visMesh->setBlendingMode(Renderer::BLEND_MODE_NORMAL);
- }
- EditCurve::~EditCurve() {
- }
- CurveEditor::CurveEditor() : UIWindow("", 440, 160) {
-
- closeOnEscape = true;
-
- bg = new UIRect(300, 100);
- bg->setColor(0.1, 0.1, 0.1, 1.0);
- addChild(bg);
- bg->setPosition(160, 63);
- bg->processInputEvents = true;
- bg->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
-
- selectorImage = new UIImage("main/selector.png", 24, 24);
- addChild(selectorImage);
-
- selectButton = new UIImageButton("main/arrow.png", 1.0, 24, 24);
- addChild(selectButton);
- selectButton->addEventListener(this, UIEvent::CLICK_EVENT);
- selectButton->setPosition(170, 33);
- addButton = new UIImageButton("main/arrow_add.png", 1.0, 24, 24);
- addChild(addButton);
- addButton->addEventListener(this, UIEvent::CLICK_EVENT);
- addButton->setPosition(170 + 32, 33);
- removeButton = new UIImageButton("main/arrow_remove.png", 1.0, 24, 24);
- addChild(removeButton);
- removeButton->addEventListener(this, UIEvent::CLICK_EVENT);
- removeButton->setPosition(170 + 64, 33);
-
- selectorImage->setPosition(selectButton->getPosition().x, selectButton->getPosition().y);
- selectedCurve = NULL;
- setMode(0);
-
- treeContainer = new UITreeContainer("boxIcon.png", L"Curves", 145, 135);
- treeContainer->getRootNode()->toggleCollapsed();
- treeContainer->getRootNode()->addEventListener(this, UITreeEvent::SELECTED_EVENT);
- treeContainer->setPosition(12, 33);
-
- treeContainer->getRootNode()->setUserData(NULL);
-
- addChild(treeContainer);
- }
- void CurveEditor::onClose() {
- visible = false;
- enabled = false;
- }
- void CurveEditor::clearCurves() {
- selectedCurve = NULL;
- treeContainer->getRootNode()->clearTree();
- for(int i=0; i < curves.size(); i++) {
- removeChild(curves[i]);
- delete curves[i];
- }
-
- curves.clear();
- }
- void CurveEditor::addCurve(String name, BezierCurve *curve, Color curveColor) {
- UITree *newNode = treeContainer->getRootNode()->addTreeChild("main/curve_icon.png", name);
- EditCurve *editCurve = new EditCurve(curve, curveColor);
- addChild(editCurve);
- editCurve->setPosition(160, 63);
- curves.push_back(editCurve);
-
- newNode->setUserData((void*) editCurve);
-
- }
- void CurveEditor::setMode(unsigned int mode) {
- this->mode = mode;
- if(selectedCurve) {
- selectedCurve->setMode(mode);
- }
- }
- void CurveEditor::handleEvent(Event *event) {
-
- if(mode == MODE_ADD) {
- if(event->getDispatcher() == bg) {
- if(event->getEventCode() == InputEvent::EVENT_MOUSEDOWN) {
- InputEvent *inputEvent = (InputEvent*)event;
- if(selectedCurve) {
- Vector2 pos = inputEvent->mousePosition;
- pos.x = pos.x/300.0;
- pos.y = 1.0-(pos.y/100.0);
-
- BezierCurve *targetCurve = selectedCurve->targetCurve;
-
- bool done = false;
- for(int i=0; i < targetCurve->getNumControlPoints(); i++) {
- if(pos.x < targetCurve->getControlPoint(i)->p2.x && !done) {
- targetCurve->insertPoint = targetCurve->getControlPoint(i);
- done = true;
- }
- }
-
- targetCurve->addControlPoint2dWithHandles(pos.x-0.1, pos.y, pos.x, pos.y, pos.x + 0.1, pos.y);
- selectedCurve->updatePoints();
- selectedCurve->updateCurve();
- }
- }
- }
- }
-
- if(event->getDispatcher() == selectButton) {
- selectorImage->setPosition(selectButton->getPosition().x, selectButton->getPosition().y);
- setMode(0);
- }
- if(event->getDispatcher() == addButton) {
- selectorImage->setPosition(addButton->getPosition().x, addButton->getPosition().y );
- setMode(1);
- }
- if(event->getDispatcher() == removeButton) {
- selectorImage->setPosition(removeButton->getPosition().x, removeButton->getPosition().y);
- setMode(2);
- }
-
- if(event->getDispatcher() == treeContainer->getRootNode()) {
- if(event->getEventCode() == UITreeEvent::SELECTED_EVENT){
- EditCurve *curve = (EditCurve *)treeContainer->getRootNode()->getSelectedNode()->getUserData();
- if(selectedCurve) {
- selectedCurve->Deactivate();
- }
- selectedCurve = curve;
- if(curve) {
- curve->Activate();
- curve->setMode(mode);
- curve->getParentEntity()->moveChildTop(curve);
- }
- }
- }
-
- UIWindow::handleEvent(event);
- }
- CurveEditor::~CurveEditor() {
- }
- EditorHolder::EditorHolder(PolycodeProject *project, PolycodeEditorManager *editorManager, EditorHolder *parentHolder) : UIElement() {
- this->editorManager = editorManager;
- this->parentHolder = parentHolder;
- this->project = project;
-
- currentEditor = NULL;
-
- holderBar = new UIElement();
- addChild(holderBar);
-
- snapToPixels = true;
-
- headerBg = new UIRect(30, 30);
- holderBar->addChild(headerBg);
- headerBg->color.setColorHexFromString(CoreServices::getInstance()->getConfig()->getStringValue("Polycode", "uiHeaderBgColor"));
-
- vSplitButton = new UIImageButton("main/editor_vsplit.png", 1.0, 19, 13);
- holderBar->addChild(vSplitButton);
- vSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
- hSplitButton = new UIImageButton("main/editor_hsplit.png", 1.0, 19, 13);
- holderBar->addChild(hSplitButton);
- hSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
- mergeSplitButton = new UIImageButton("main/editor_mergesplit.png", 1.0, 19, 13);
- holderBar->addChild(mergeSplitButton);
- mergeSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- closeFileButton = new UIImageButton("main/remove_icon.png", 1.0, 12, 12);
- holderBar->addChild(closeFileButton);
- closeFileButton->setPosition(10, 8);
- closeFileButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- currentFileSelector = new UIComboBox(globalMenu, 350);
- currentFileSelector->addEventListener(this, UIEvent::CHANGE_EVENT);
- holderBar->addChild(currentFileSelector);
- currentFileSelector->setPosition(30, 3);
- addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
-
- vSizer = NULL;
- hSizer = NULL;
-
- firstChildHolder = NULL;
- secondChildHolder = NULL;
-
- displayFilePathInSelector = false;
-
- initialUpdate = true;
- updateFileSelector();
-
- editorToMerge = NULL;
-
- isActive = false;
- }
- ObjectEntry *EditorHolder::getEditorHolderConfig() {
- ObjectEntry *configEntry = new ObjectEntry();
- configEntry->name = "editor_holder";
-
- if(vSizer) {
- configEntry->addChild("split", "vsplit");
- ObjectEntry *childEditors = configEntry->addChild("child_editors");
- childEditors->addChild(firstChildHolder->getEditorHolderConfig())->addChild("size", vSizer->getMainHeight());
- childEditors->addChild(secondChildHolder->getEditorHolderConfig());
- } else if(hSizer) {
- configEntry->addChild("split", "hsplit");
- ObjectEntry *childEditors = configEntry->addChild("child_editors");
- childEditors->addChild(firstChildHolder->getEditorHolderConfig())->addChild("size", hSizer->getMainWidth());
- childEditors->addChild(secondChildHolder->getEditorHolderConfig());
- } else {
- configEntry->addChild("split", "none");
- if(currentEditor) {
- configEntry->addChild("file_name", currentEditor->getFilePath());
- ObjectEntry *editorConfig = currentEditor->getEditorConfig();
- if(editorConfig) {
- configEntry->addChild(editorConfig)->name = "editor_config";
- }
- }
- }
- return configEntry;
- }
- void EditorHolder::applyConfig(ObjectEntry *entry) {
- ObjectEntry *splitEntry = (*entry)["split"];
- if(splitEntry) {
- if(splitEntry->stringVal == "none") {
- ObjectEntry *fileNameEntry = (*entry)["file_name"];
- if(fileNameEntry) {
- OSFileEntry file = OSFileEntry(fileNameEntry->stringVal, OSFileEntry::TYPE_FILE);
- PolycodeEditor *editor = globalEditorManager->openFile(file);
- if(editor) {
- setEditor(editor);
- ObjectEntry *editorConfig = (*entry)["editor_config"];
- if(editorConfig) {
- editor->applyEditorConfig(editorConfig);
- }
- }
- }
- } else {
- if(splitEntry->stringVal == "hsplit") {
- makeHSplit();
- } else {
- makeVSplit();
- }
-
- ObjectEntry *childEntries = (*entry)["child_editors"];
- if(childEntries) {
- ObjectEntry *firstChildEntry = (*childEntries)[0];
- if(firstChildEntry) {
- firstChildHolder->applyConfig(firstChildEntry);
- if(vSizer) {
- vSizer->setMainHeightWithMinimum((*firstChildEntry)["size"]->NumberVal);
- } else if(hSizer) {
- hSizer->setMainWidthWithMinimum((*firstChildEntry)["size"]->NumberVal);
- }
- }
- ObjectEntry *secondChildEntry = (*childEntries)[1];
- if(secondChildEntry) {
- secondChildHolder->applyConfig(secondChildEntry);
- }
- }
-
- }
- }
- }
- void EditorHolder::setActive(bool val) {
- isActive = val;
-
- if(firstChildHolder) {
- firstChildHolder->setActive(val);
- return;
- }
-
- if(val) {
- headerBg->color.setColorHexFromString(CoreServices::getInstance()->getConfig()->getStringValue("Polycode", "uiAccentColor"));
- if(activeEditorHolder && activeEditorHolder != this) {
- activeEditorHolder->setActive(false);
- }
- activeEditorHolder = this;
- editorManager->setCurrentEditor(currentEditor);
- } else {
- headerBg->color.setColorHexFromString(CoreServices::getInstance()->getConfig()->getStringValue("Polycode", "uiHeaderBgColor"));
- }
- }
- void EditorHolder::updateFileSelector() {
- currentFileSelector->removeAllHandlersForListener(this);
- currentFileSelector->clearItems();
-
- std::vector<PolycodeEditor*> editors = editorManager->getOpenEditorsForProject(project);
-
- for(int i=0; i < editors.size(); i++) {
- OSFileEntry entry(editors[i]->getFilePath(), OSFileEntry::TYPE_FILE);
-
- String projName = editors[i]->parentProject->getProjectName();
- String rootFolder = editors[i]->parentProject->getRootFolder();
- String filePath = editors[i]->getFilePath();
-
- String fullEntry = filePath;
- if(filePath.find(rootFolder) != -1) {
- fullEntry = projName + filePath.substr(rootFolder.size(), filePath.size()-1);
- }
- if(editors[i]->hasChanges()) {
- if (displayFilePathInSelector)
- currentFileSelector->addComboItem("* "+fullEntry, (void*)editors[i]);
- else
- currentFileSelector->addComboItem("* "+entry.name, (void*)editors[i]);
- } else {
- if (displayFilePathInSelector)
- currentFileSelector->addComboItem(fullEntry, (void*)editors[i]);
- else
- currentFileSelector->addComboItem(entry.name, (void*)editors[i]);
- }
-
- if(currentEditor == editors[i]) {
- if(!initialUpdate) {
- currentFileSelector->setSelectedIndex(i);
- }
- }
- }
-
- if(firstChildHolder) {
- firstChildHolder->updateFileSelector();
- }
- if(secondChildHolder) {
- secondChildHolder->updateFileSelector();
- }
- currentFileSelector->addEventListener(this, UIEvent::CHANGE_EVENT);
- initialUpdate = false;
- }
- void EditorHolder::setEditor(PolycodeEditor *newEditor) {
- if(vSizer || hSizer) {
- firstChildHolder->setEditor(newEditor);
- return;
- }
- if(currentEditor) {
- removeChild(currentEditor);
- currentEditor->setEditorHolder(NULL);
- }
- currentEditor = newEditor;
- if(currentEditor) {
- EditorHolder *currentEditorHolder = currentEditor->getEditorHolder();
- if(currentEditorHolder) {
- currentEditorHolder->setEditor(NULL);
- }
- if(currentEditor) {
- currentEditor->setEditorHolder(this);
- }
- addChild(currentEditor);
- }
- updateFileSelector();
- Resize(getWidth(), getHeight());
-
- if(isActive) {
- editorManager->setCurrentEditor(currentEditor);
- }
- }
- PolycodeEditor *EditorHolder::getEditor() {
- return currentEditor;
- }
- void EditorHolder::makeVSplit() {
- holderBar->visible = false;
- holderBar->enabled = false;
- vSizer = new UIVSizer(getWidth(), getHeight(), getHeight()/2.0, true);
- vSizer->setMinimumSize(200);
- vSizer->setProportionalResize(true);
-
- addChild(vSizer);
- firstChildHolder = new EditorHolder(project, editorManager, this);
- firstChildHolder->addEventListener(this, UIEvent::CLOSE_EVENT);
- vSizer->addTopChild(firstChildHolder);
- if(isActive) {
- firstChildHolder->setActive(true);
- }
- secondChildHolder = new EditorHolder(project, editorManager, this);
- secondChildHolder->addEventListener(this, UIEvent::CLOSE_EVENT);
- vSizer->addBottomChild(secondChildHolder);
- if(currentEditor) {
- removeChild(currentEditor);
- currentEditor->setEditorHolder(NULL);
- firstChildHolder->setEditor(currentEditor);
- currentEditor = NULL;
- }
- Resize(getWidth(), getHeight());
- }
- void EditorHolder::makeHSplit() {
- holderBar->visible = false;
- holderBar->enabled = false;
-
- hSizer = new UIHSizer(getWidth(), getHeight(), getWidth()/2.0, true);
- hSizer->setMinimumSize(200);
- hSizer->setProportionalResize(true);
-
- addChild(hSizer);
- firstChildHolder = new EditorHolder(project, editorManager, this);
- firstChildHolder->addEventListener(this, UIEvent::CLOSE_EVENT);
- hSizer->addLeftChild(firstChildHolder);
- secondChildHolder = new EditorHolder(project, editorManager, this);
- secondChildHolder->addEventListener(this, UIEvent::CLOSE_EVENT);
- hSizer->addRightChild(secondChildHolder);
- if(isActive) {
- firstChildHolder->setActive(true);
- }
-
- if(currentEditor) {
- removeChild(currentEditor);
- currentEditor->setEditorHolder(NULL);
- firstChildHolder->setEditor(currentEditor);
- currentEditor = NULL;
- }
- Resize(getWidth(), getHeight());
- }
- void EditorHolder::handleEvent(Event *event) {
- if(event->getDispatcher() == this) {
- if(holderBar->visible) {
- setActive(true);
- }
- } else if(event->getDispatcher() == vSplitButton) {
- makeVSplit();
- } else if(event->getDispatcher() == hSplitButton) {
- makeHSplit();
- } else if(event->getDispatcher() == currentFileSelector) {
- PolycodeEditor *editor = (PolycodeEditor*) currentFileSelector->getSelectedItem()->data;
- if(currentEditor != editor) {
- setEditor(editor);
- Resize(getWidth(), getHeight());
- }
-
- } else if(event->getDispatcher() == mergeSplitButton) {
- if(parentHolder) {
- parentHolder->mergeSides(this);
- Resize(getWidth(), getHeight());
- }
- } else if(event->getDispatcher() == closeFileButton) {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- } else if(event->getDispatcher() == firstChildHolder || event->getDispatcher() == secondChildHolder) {
- if(event->getEventCode() == UIEvent::CLOSE_EVENT) {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- }
- Resize(getWidth(), getHeight());
- }
-
- UIElement::handleEvent(event);
- }
- void EditorHolder::Update() {
- if(editorToMerge) {
- _mergeSides(editorToMerge);
- editorToMerge = NULL;
- }
- }
- void EditorHolder::mergeSides(EditorHolder *mainHolder) {
- editorToMerge = mainHolder;
- }
- void EditorHolder::_mergeSides(EditorHolder *mainHolder) {
- holderBar->visible = true;
- holderBar->enabled = true;
- activeEditorHolder = this;
-
- PolycodeEditor *mainHolderEditor = mainHolder->getEditor();
-
- if(firstChildHolder) {
- PolycodeEditor *holderEditor = firstChildHolder->getEditor();
- if(holderEditor) {
- holderEditor->setEditorHolder(NULL);
- }
- }
- if(secondChildHolder) {
- PolycodeEditor *holderEditor = secondChildHolder->getEditor();
- if(holderEditor) {
- holderEditor->setEditorHolder(NULL);
- }
- }
-
- if(vSizer) {
- removeChild(vSizer);
- delete vSizer;
- }
- if(hSizer) {
- removeChild(hSizer);
- delete hSizer;
- }
- delete firstChildHolder;
- delete secondChildHolder;
-
- firstChildHolder = NULL;
- secondChildHolder = NULL;
- vSizer = NULL;
- hSizer = NULL;
-
- setActive(true);
- setEditor(mainHolderEditor);
- }
- EditorHolder::~EditorHolder() {
- if(vSizer) {
- removeChild(vSizer);
- delete vSizer;
- }
- if(hSizer) {
- removeChild(hSizer);
- delete hSizer;
- }
-
- if(firstChildHolder) {
- delete firstChildHolder;
- }
- if(secondChildHolder) {
- delete secondChildHolder;
- }
- }
-
- void EditorHolder::Resize(Number width, Number height) {
- if(headerBg->visible) {
- headerBg->Resize(width, 30);
- hSplitButton->setPosition(width - 30, 7);
- vSplitButton->setPosition(width - 55, 7);
- if(parentHolder) {
- mergeSplitButton->visible = true;
- mergeSplitButton->enabled = true;
- mergeSplitButton->setPosition(width - 80, 7);
- currentFileSelector->Resize(width - 125, currentFileSelector->getHeight());
- } else {
- mergeSplitButton->visible = false;
- mergeSplitButton->enabled = false;
- currentFileSelector->Resize(width - 100, currentFileSelector->getHeight());
- }
- }
-
-
- if(currentEditor) {
- currentEditor->setPosition(0, 30);
- currentEditor->Resize(width, height-30);
- }
-
- if(vSizer) {
- vSizer->Resize(width, height);
- }
- if(hSizer) {
- hSizer->Resize(width, height);
- }
-
- UIElement::Resize(width, height);
- }
- PolycodeProjectTab::PolycodeProjectTab(String caption, PolycodeProject *project, PolycodeEditorManager *editorManager) : UIElement() {
- tabName = caption;
-
- this->editorManager = editorManager;
- editorHolder = new EditorHolder(project, editorManager, NULL);
- editorHolder->setActive(true);
- editorHolder->addEventListener(this, UIEvent::CLOSE_EVENT);
-
- mainSizer = new UIHSizer(100,100,200,true);
- mainSizer->setMinimumSize(100);
- addChild(mainSizer);
- projectBrowser = new PolycodeProjectBrowser(project);
- mainSizer->addLeftChild(projectBrowser);
- mainSizer->addRightChild(editorHolder);
- active = false;
- projectBrowser->treeContainer->getRootNode()->addEventListener(this, UITreeEvent::DRAG_START_EVENT);
- }
- void PolycodeProjectTab::setActive(bool val) {
- active = val;
- if(!active) {
- projectBrowser->removeAllHandlers();
- }
- }
- bool PolycodeProjectTab::isActive() {
- return active;
- }
- void PolycodeProjectTab::handleEvent(Event *event) {
- if(event->getDispatcher() == editorHolder && event->getEventCode() == UIEvent::CLOSE_EVENT) {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- }
- UIElement::handleEvent(event);
- }
- String PolycodeProjectTab::getTabName() {
- return tabName;
- }
- ObjectEntry *PolycodeProjectTab::getTabConfig() {
- ObjectEntry *configEntry = new ObjectEntry();
- configEntry->name = "tab";
-
- configEntry->addChild(projectBrowser->getBrowserConfig());
-
- configEntry->addChild("tab_name", tabName);
- configEntry->addChild("tab_active", isActive());
-
- configEntry->addChild(editorHolder->getEditorHolderConfig());
- return configEntry;
- }
- void PolycodeProjectTab::applyTabConfig(ObjectEntry *tabEntry) {
- ObjectEntry *browserEntry = (*tabEntry)["project_browser"];
- if(browserEntry) {
- ObjectEntry *browserWidthEntry = (*browserEntry)["width"];
- if(browserWidthEntry) {
- mainSizer->setMainWidth(browserWidthEntry->NumberVal);
- }
- projectBrowser->applyBrowserConfig(browserEntry);
- }
-
- ObjectEntry *editorHolderEntry = (*tabEntry)["editor_holder"];
- if(editorHolderEntry) {
- editorHolder->applyConfig(editorHolderEntry);
- }
- }
- void PolycodeProjectTab::setTabName(String newName) {
- tabName = newName;
- }
- void PolycodeProjectTab::Resize(Number width, Number height) {
- mainSizer->Resize(width, height);
- UIElement::Resize(width, height);
- }
- EditorHolder *PolycodeProjectTab::getEditorHolder() {
- return editorHolder;
- }
- void PolycodeProjectTab::showEditor(PolycodeEditor *editor) {
- if(!activeEditorHolder) {
- return;
- }
-
- if(activeEditorHolder->getEditor()) {
- activeEditorHolder->setEditor(NULL);
- }
-
- activeEditorHolder->setEditor(editor);
- editor->Activate();
- Resize(getWidth(), getHeight());
- }
- PolycodeProjectBrowser *PolycodeProjectTab::getProjectBrowser() {
- return projectBrowser;
- }
- PolycodeProjectTab::~PolycodeProjectTab() {
- }
- PolycodeTabButton::PolycodeTabButton(PolycodeProjectTab *tab) : UIElement() {
- this->tab = tab;
- bgRect = new UIImage("main/tab_bg.png", 150,30);
- addChild(bgRect);
- bgRect->processInputEvents = true;
- processInputEvents = true;
- bgRect->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
-
- setWidth(150);
- setHeight(30);
-
- tabLabel = new UILabel(tab->getTabName().toUpperCase(), 16, "section");
- tabLabel->setColor(0.0, 0.0, 0.0, 1.0);
- tabLabel->setPosition(getWidth()-tabLabel->getWidth()-10.0, ((getHeight()-tabLabel->getHeight())/2.0) - 3.0);
- addChild(tabLabel);
-
- closeButton = new UIImageButton("main/tab_close_button.png", 1.0, 18, 18);
- closeButton->setPosition(4.0, floor((30.0 - closeButton->getHeight()) / 2.0));
- addChild(closeButton);
- closeButton->blockMouseInput = true;
- closeButton->addEventListener(this, UIEvent::CLICK_EVENT);
- }
- void PolycodeTabButton::updateLabel() {
- tabLabel->setText(tab->getTabName().toUpperCase());
- tabLabel->setPosition(getWidth()-tabLabel->getWidth()-10.0, ((getHeight()-tabLabel->getHeight())/2.0) - 3.0);
- }
- void PolycodeTabButton::handleEvent(Event *event) {
- if(event->getDispatcher() == renamePopup) {
- renamePopup->removeAllHandlersForListener(this);
- tabLabel->setText(renamePopup->getValue().toUpperCase());
- tab->setTabName(renamePopup->getValue());
- tabLabel->setPosition(getWidth()-tabLabel->getWidth()-10.0, ((getHeight()-tabLabel->getHeight())/2.0) - 3.0);
- }
- if(event->getDispatcher() == menu) {
- if(menu->getSelectedItem()->_id == "close_tab") {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- } else if(menu->getSelectedItem()->_id == "rename_tab") {
- renamePopup = globalFrame->showTextInput("Enter new tab name.", "rename_tab", tab->getTabName());
- renamePopup->addEventListener(this, UIEvent::OK_EVENT);
- }
- }
-
- if(event->getDispatcher() == closeButton) {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- }
-
- if(event->getDispatcher() == bgRect) {
- if(event->getEventCode() == InputEvent::EVENT_MOUSEDOWN) {
- dispatchEvent(new Event(), Event::SELECT_EVENT);
- InputEvent *inputEvent = (InputEvent*) event;
- if(inputEvent->getMouseButton() == CoreInput::MOUSE_BUTTON2) {
- menu = globalMenu->showMenuAtMouse(120);
- menu->addOption("Rename tab", "rename_tab");
- menu->addOption("Close tab", "close_tab");
- menu->addEventListener(this, UIEvent::OK_EVENT);
- }
- }
- }
- UIElement::handleEvent(event);
- }
- void PolycodeTabButton::setActive(bool val) {
- if(val) {
- bgRect->color.a = 0.4;
- } else {
- bgRect->color.a = 0.2;
- }
- }
- PolycodeProjectTab *PolycodeTabButton::getTab() {
- return tab;
- }
- PolycodeTabButton::~PolycodeTabButton() {
- }
- PolycodeProjectFrame::PolycodeProjectFrame(PolycodeProject *project, PolycodeEditorManager *editorManager) {
- tabToClose = NULL;
- this->editorManager = editorManager;
- this->project = project;
- lastActiveEditorHolder = NULL;
- tabButtonAnchor = new UIElement();
- addChild(tabButtonAnchor);
- tabButtonAnchor->setPosition(400, -30);
-
- activeTab = NULL;
-
- newTabButton = new UIImageButton("main/new_tab_button.png", 1.0, 27, 26);
- tabButtonAnchor->addChild(newTabButton);
- newTabButton->addEventListener(this, UIEvent::CLICK_EVENT);
- addNewTab("Default");
- }
- void PolycodeProjectFrame::showNextTab() {
- for(int i=0; i < tabs.size(); i++) {
- if(tabs[i] == activeTab) {
- if(i < tabs.size()-1) {
- showTab(tabs[i+1]);
- return;
- } else {
- showTab(tabs[0]);
- return;
- }
- }
- }
- }
- void PolycodeProjectFrame::showPreviousTab() {
- for(int i=0; i < tabs.size(); i++) {
- if(tabs[i] == activeTab) {
- if(i > 0) {
- showTab(tabs[i-1]);
- return;
- } else {
- showTab(tabs[tabs.size()-1]);
- return;
- }
- }
- }
- }
- PolycodeProjectTab *PolycodeProjectFrame::getTabAtIndex(unsigned int index) {
- return tabs[index];
- }
- unsigned int PolycodeProjectFrame::getNumTabs() {
- return tabs.size();
- }
- PolycodeProjectTab *PolycodeProjectFrame::getActiveTab() {
- return activeTab;
- }
- PolycodeProjectTab *PolycodeProjectFrame::addNewTab(String caption) {
- PolycodeProjectTab *newTab = new PolycodeProjectTab(caption, project, editorManager);
- tabs.push_back(newTab);
-
- PolycodeTabButton *newTabButton = new PolycodeTabButton(newTab);
- tabButtonAnchor->addChild(newTabButton);
- tabButtons.push_back(newTabButton);
- newTabButton->addEventListener(this, Event::SELECT_EVENT);
- newTabButton->addEventListener(this, UIEvent::CLOSE_EVENT);
- showTab(newTab);
- return newTab;
- }
- void PolycodeProjectFrame::Update() {
- if(tabToClose) {
-
- // can't close the last tab
- if(tabs.size() == 1) {
- tabToClose = NULL;
- return;
- }
-
- for(int i=0; i < tabs.size(); i++) {
- if(tabs[i] == tabToClose) {
- tabs.erase(tabs.begin()+i);
- break;
- }
- }
-
- for(int i=0; i < tabButtons.size(); i++) {
- if(tabButtons[i]->getTab() == tabToClose) {
- tabButtonAnchor->removeChild(tabButtons[i]);
- delete tabButtons[i];
- tabButtons.erase(tabButtons.begin()+i);
- break;
- }
- }
-
- if(tabToClose == activeTab) {
- showTab(tabs[0]);
- }
-
- delete tabToClose;
- tabToClose = NULL;
- restructTabs();
- }
- }
- void PolycodeProjectFrame::closeTab(PolycodeProjectTab *tab) {
- tabToClose = tab;
- }
- void PolycodeProjectFrame::showTab(PolycodeProjectTab *tab) {
- if(activeTab) {
- activeTab->setActive(false);
- activeTab->removeAllHandlersForListener(this);
- removeChild(activeTab);
- }
- addChild(tab);
- tab->addEventListener(this, UIEvent::CLOSE_EVENT);
- tab->setActive(true);
- tab->getEditorHolder()->setActive(true);
- tab->Resize(getWidth(), getHeight());
- activeTab = tab;
- restructTabs();
- dispatchEvent(new UIEvent(), Event::CHANGE_EVENT);
- }
- void PolycodeProjectFrame::restructTabs() {
- int i;
- for(i=0; i < tabButtons.size(); i++) {
- tabButtons[i]->setPosition(i * 152.0, 0.0);
- tabButtons[i]->setActive(tabButtons[i]->getTab()->isActive());
- tabButtons[i]->updateLabel();
- }
- newTabButton->setPosition((i * 152) + 3, 0.0);
- }
- ObjectEntry *PolycodeProjectFrame::getFrameConfig() {
- ObjectEntry *configEntry = new ObjectEntry();
- configEntry->name = "frame";
-
- ObjectEntry *tabsEntry = configEntry->addChild("tabs");
-
- for(int i=0; i < tabs.size(); i++) {
- tabsEntry->addChild(tabs[i]->getTabConfig());
- }
- return configEntry;
- }
- void PolycodeProjectFrame::handleEvent(Event *event) {
- for(int i=0; i < tabs.size(); i++) {
- if(event->getDispatcher() == tabs[i] && event->getEventCode() == UIEvent::CLOSE_EVENT) {
- dispatchEvent(new UIEvent, UIEvent::CLOSE_EVENT);
- return;
- }
- }
-
- if(event->getDispatcher() == newTabButton) {
- addNewTab();
- } else {
- for(int i=0; i < tabButtons.size(); i++) {
- if(event->getDispatcher() == tabButtons[i]) {
- if(event->getEventCode() == Event::SELECT_EVENT) {
- showTab(tabButtons[i]->getTab());
- break;
- } else if(event->getEventCode() == UIEvent::CLOSE_EVENT) {
- closeTab(tabButtons[i]->getTab());
- break;
- } else if(event->getEventCode() == UIEvent::CHANGE_EVENT) {
- dispatchEvent(new UIEvent(), UIEvent::CHANGE_EVENT);
- break;
- }
- }
- }
- }
- }
- PolycodeProject *PolycodeProjectFrame::getProject() {
- return project;
- }
- void PolycodeProjectFrame::Resize(Number width, Number height) {
- activeTab->Resize(width, height);
- UIElement::Resize(width, height);
- }
- PolycodeProjectFrame::~PolycodeProjectFrame() {
- }
- PolycodeFrame::PolycodeFrame(PolycodeEditorManager *editorManager) : UIElement() {
- this->editorManager = editorManager;
- activeProjectFrame = NULL;
- consoleSize = 200;
-
- globalFrame = this;
- processInputEvents = true;
- willHideModal = false;
- showingConsole = true;
- modalChild = NULL;
-
- welcomeEntity = new Entity();
- welcomeEntity->processInputEvents = true;
- addChild(welcomeEntity);
- welcomeImage = new UIImage("main/welcome.png", 759, 207);
- welcomeEntity->addChild(welcomeImage);
- welcomeEntity->snapToPixels = true;
-
- newProjectButton = new UIButton("Create A New Project!", 220);
- newProjectButton->setPosition(260,120);
- newProjectButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- examplesButton = new UIButton("Browse Example Projects!", 220);
- examplesButton->setPosition(490,120);
- examplesButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- welcomeEntity->addChild(newProjectButton);
- welcomeEntity->addChild(examplesButton);
-
-
- topBarBg = new UIRect(2,2);
- topBarBg->setColorInt(21, 18, 17, 255);
- topBarBg->setAnchorPoint(-1.0, -1.0, 0.0);
- topBarBg->processInputEvents = true;
- topBarBg->addEventListener(this, InputEvent::EVENT_MOUSEMOVE);
- topBarBg->blockMouseInput = true;
- addChild(topBarBg);
- consoleSizer = new UIVSizer(100,100,200, false);
- console = new PolycodeConsole();
- consoleSizer->addBottomChild(console);
- addChild(consoleSizer);
- consoleSizer->setPosition(0.0, 45);
-
- logo = new UIImage("main/barLogo.png", 38, 38);
- addChild(logo);
-
- playButton = new UIImageButton("main/play_button.png", 1.0, 32, 32);
- addChild(playButton);
- playButton->setPosition(10,5);
- stopButton = new UIImageButton("main/stop_button.png", 1.0, 32, 32);
- addChild(stopButton);
- stopButton->setPosition(10,5);
- currentProjectSelector = new UIComboBox(globalMenu, 300);
- currentProjectSelector->addEventListener(this, UIEvent::CHANGE_EVENT);
- addChild(currentProjectSelector);
- currentProjectSelector->setPosition(60, 10);
-
- resizer = new UIImage("main/corner_resize.png", 14, 14);
- addChild(resizer);
- resizer->setColor(0,0,0,0.4);
-
- modalBlocker = new UIRect(10,10);
- modalBlocker->setBlendingMode(Renderer::BLEND_MODE_NORMAL);
- modalBlocker->setColor(0,0,0,0.4);
- modalBlocker->setAnchorPoint(-1.0, -1.0, 0.0);
- modalBlocker->enabled = false;
- modalBlocker->blockMouseInput = true;
- modalBlocker->processInputEvents = true;
- addChild(modalBlocker);
-
- assetBrowser = new AssetBrowser();
- assetBrowser->visible = false;
-
- newProjectWindow = new NewProjectWindow();
- newProjectWindow->visible = false;
-
- exampleBrowserWindow = new ExampleBrowserWindow();
- exampleBrowserWindow->visible = false;
- settingsWindow = new SettingsWindow();
- settingsWindow->visible = false;
-
- newFileWindow = new NewFileWindow();
- newFileWindow->visible = false;
-
- exportProjectWindow = new ExportProjectWindow();
- exportProjectWindow->visible = false;
-
- textInputPopup = new TextInputPopup();
- textInputPopup->visible = false;
-
- yesNoPopup = new YesNoPopup();
- yesNoPopup->visible = false;
-
- yesNoCancelPopup = new YesNoCancelPopup();
- yesNoCancelPopup->visible = false;
-
-
- aboutWindow = new UIWindow("", 800, 440);
- aboutWindow->closeOnEscape = true;
- UIImage *aboutImage = new UIImage("main/about.png", 321, 122);
- aboutWindow->addChild(aboutImage);
- aboutImage->setPosition(20, 40);
- aboutWindow->visible = false;
- aboutOKButton = new UIButton("OK", 100);
- aboutWindow->addChild(aboutOKButton);
- aboutOKButton->setPosition(700, 420);
- aboutOKButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
-
- assetImporterWindow = new AssetImporterWindow();
-
-
- UILabel *versionLabel = new UILabel("version 0.8.2", 12, "mono");
- aboutWindow->addChild(versionLabel);
- versionLabel->setPosition(20, 430);
- versionLabel->color.a = 1.0;
-
- isDragging = false;
- dragLabel = new UILabel("NONE", 11, "sans");
- dragLabel->setPosition(0,-15);
-
- dragEntity = new Entity();
- dragEntity->addChild(dragLabel);
- addChild(dragEntity);
- dragEntity->visible = false;
-
-
- CoreServices::getInstance()->getCore()->getInput()->addEventListener(this, InputEvent::EVENT_MOUSEUP);
- CoreServices::getInstance()->getCore()->getInput()->addEventListener(this, InputEvent::EVENT_MOUSEMOVE);
- CoreServices::getInstance()->getCore()->getInput()->addEventListener(this, InputEvent::EVENT_KEYDOWN);
-
- curveEditor = new CurveEditor();
- addChild(curveEditor);
- curveEditor->setPosition(200,100);
- curveEditor->visible = false;
- curveEditor->enabled = false;
-
-
- globalColorPicker = new UIColorPicker();
- globalColorPicker->setPosition(300,300);
- addChild(globalColorPicker);
- modalRoot = new UIElement();
- addChild(modalRoot);
-
- fileDialogBlocker = new UIRect(100, 100);
- fileDialogBlocker->setAnchorPoint(-1.0, -1.0, 0.0);
- addChild(fileDialogBlocker);
- fileDialogBlocker->setColor(0.0, 0.0, 0.0, 0.5);
- fileDialogBlocker->processInputEvents = true;
- fileDialogBlocker->blockMouseInput = true;
- fileDialogBlocker->visible = false;
- fileDialogBlocker->enabled = false;
- fileBrowserRoot = new UIElement();
- addChild(fileBrowserRoot);
- fileDialog = NULL;
-
- displayFilePathInSelector = false;
- }
- void PolycodeFrame::showFileBrowser(String baseDir, bool foldersOnly, std::vector<String> extensions, bool allowMultiple) {
-
- if(fileDialog)
- delete fileDialog;
- fileDialog = new UIFileDialog(baseDir, foldersOnly, extensions, allowMultiple);
- fileDialog->addEventListener(this, UIEvent::CANCEL_EVENT);
- fileDialog->addEventListener(this, UIEvent::OK_EVENT);
- fileBrowserRoot->addChild(fileDialog);
- fileDialog->setPosition(100,100);
-
- fileDialogBlocker->visible = true;
- fileDialogBlocker->enabled = true;
- }
- void PolycodeFrame::showCurveEditor() {
- curveEditor->visible = true;
- curveEditor->enabled = true;
- }
- void PolycodeFrame::showModal(UIWindow *modalChild) {
- modalBlocker->enabled = true;
-
- focusChild(NULL);
-
- this->modalChild = modalChild;
- modalRoot->addChild(modalChild);
- modalChild->showWindow();
- modalChild->addEventListener(this, UIEvent::CLOSE_EVENT);
- Resize(getWidth(), getHeight());
-
- if(modalChild == yesNoPopup) {
- yesNoPopup->focusChild(yesNoPopup->okButton);
- }
- CoreServices::getInstance()->getCore()->setCursor(Core::CURSOR_ARROW);
- }
- void PolycodeFrame::hideModal() {
- if(modalChild) {
- modalRoot->removeChild(modalChild);
- modalChild->removeEventListener(this, UIEvent::CLOSE_EVENT);
- modalChild->hideWindow();
- modalChild = NULL;
- }
- modalBlocker->enabled = false;
- }
- bool PolycodeFrame::isShowingConsole() {
- return showingConsole;
- }
-
- void PolycodeFrame::showConsole() {
- if(!showingConsole)
- toggleConsole();
- }
- void PolycodeFrame::hideConsole() {
- if(showingConsole)
- toggleConsole();
- }
- void PolycodeFrame::toggleConsole() {
- if(showingConsole) {
- consoleSize = consoleSizer->getMainHeight();
- consoleSizer->setMainHeight(0);
- console->visible = false;
- console->enabled = false;
- } else {
- consoleSizer->setMainHeight(consoleSize);
- console->visible = true;
- console->enabled = true;
- }
- showingConsole = !showingConsole;
- }
- Number PolycodeFrame::getConsoleSize() {
- if(showingConsole) {
- return consoleSizer->getMainHeight();
- } else {
- return consoleSize;
- }
- }
- void PolycodeFrame::Update() {
- if(willHideModal) {
- hideModal();
- willHideModal = false;
- }
- }
- TextInputPopup * PolycodeFrame::showTextInput(String caption, String action, String value) {
- textInputPopup->action = action;
- textInputPopup->setCaption(caption);
- textInputPopup->setValue(value);
- showModal(textInputPopup);
- return textInputPopup;
- }
- void PolycodeFrame::showAssetBrowser(std::vector<String> extensions) {
- if(!projectManager->getActiveProject()) {
- return;
- }
- assetBrowser->setProject(projectManager->getActiveProject());
- assetBrowser->setExtensions(extensions);
- showModal(assetBrowser);
- }
- void PolycodeFrame::handleEvent(Event *event) {
- if(event->getDispatcher() == activeProjectFrame) {
- if(event->getEventCode() == Event::CHANGE_EVENT) {
- dispatchEvent(new Event(), Event::CHANGE_EVENT);
- }
- }
- if(event->getDispatcher() == activeProjectFrame) {
- if(event->getEventCode() == UIEvent::CLOSE_EVENT) {
- dispatchEvent(new UIEvent(), UIEvent::CLOSE_EVENT);
- }
- }
- if(event->getDispatcher() == currentProjectSelector) {
- PolycodeProject *project = (PolycodeProject*)currentProjectSelector->getSelectedItem()->data;
- projectManager->setActiveProject(project);
- }
-
- if(event->getDispatcher() == editorManager) {
- updateFileSelector();
- }
-
- if(event->getDispatcher() == topBarBg) {
- CoreServices::getInstance()->getCore()->setCursor(Core::CURSOR_ARROW);
- }
-
- if(event->getDispatcher() == projectManager) {
- currentProjectSelector->clearItems();
- for(int i=0; i < projectManager->getProjectCount(); i++) {
- PolycodeProject *project = projectManager->getProjectByIndex(i);
- currentProjectSelector->addComboItem(project->getProjectName(), (void*) project);
- if(projectManager->getActiveProject() == project) {
- currentProjectSelector->setSelectedIndex(i, true);
- }
- }
- }
-
- if(event->getDispatcher() == aboutOKButton && event->getEventType() == "UIEvent") {
- hideModal();
- }
-
- if(event->getDispatcher() == fileDialog && event->getEventType() == "UIEvent") {
- fileBrowserRoot->removeChild(fileDialog);
- fileDialogBlocker->visible = false;
- fileDialogBlocker->enabled = false;
- }
- if(event->getDispatcher() == CoreServices::getInstance()->getCore()->getInput()) {
- switch(event->getEventCode()) {
- case InputEvent::EVENT_MOUSEUP:
- if(isDragging) {
- /*
- if(editorHolder->currentEditor) {
- InputEvent *inputEvent = (InputEvent*) event;
- Number posX = inputEvent->mousePosition.x;
- Number posY = inputEvent->mousePosition.y;
- editorHolder->currentEditor->handleDroppedFile(draggedFile, posX, posY);
- }
- */
- }
- isDragging = false;
- dragEntity->visible = false;
- break;
- case InputEvent::EVENT_MOUSEMOVE:
- if(isDragging) {
- //dragEntity->setPosition(((InputEvent*)event)->mousePosition);
- }
- break;
- // TODO: add in key combos to switch editors in reverse order
- case InputEvent::EVENT_KEYDOWN:
- CoreInput *input = CoreServices::getInstance()->getCore()->getInput();
-
- if (input->getKeyState(KEY_LSUPER) || input->getKeyState(KEY_RSUPER)) {
- InputEvent *inEv = (InputEvent*)event;
- // commenting this out for now until issue with KEY_BACKQUOTE is figured out
- /*if (inEv->getKey() == KEY_BACKQUOTE) {
- showNextEditor();
- }*/
- if (inEv->getKey() == KEY_SLASH) {
- displayFilePathInSelector = (displayFilePathInSelector ? false : true);
- updateFileSelector();
- }
- } else if (input->getKeyState(KEY_LCTRL) || input->getKeyState(KEY_RCTRL)) {
- // InputEvent *inEv = (InputEvent*)event;
- // if (inEv->getKey() == KEY_TAB) {
- // showNextEditor();
- // } else if (inEv->getKey() == KEY_SLASH) {
- // displayFilePathInSelector = (displayFilePathInSelector ? false : true);
- // updateFileSelector();
- // }
- }
- break;
-
- }
- }
- /*
- if(event->getDispatcher() == projectBrowser->treeContainer->getRootNode()) {
- switch (event->getEventCode()) {
- case UITreeEvent::DRAG_START_EVENT:
- {
- UITreeEvent *treeEvent = (UITreeEvent*) event;
- BrowserUserData *data = (BrowserUserData*)treeEvent->selection->getUserData();
- draggedFile = data->fileEntry;
- dragLabel->setText(data->fileEntry.name);
- dragEntity->visible = true;
- isDragging = true;
- // printf("START DRAG: %s\n", data->fileEntry.name.c_str());
- }
- break;
- }
- }
- */
- if(event->getDispatcher() == modalChild) {
- if(event->getEventType() == "UIEvent" && event->getEventCode() == UIEvent::CLOSE_EVENT) {
- willHideModal = true;
- }
- } else {
- if(event->getEventType() == "UIEvent" && event->getEventCode() == UIEvent::CLICK_EVENT && event->getDispatcher() == newProjectButton) {
- showModal(newProjectWindow);
- newProjectWindow->ResetForm();
- }
-
- if(event->getEventType() == "UIEvent" && event->getEventCode() == UIEvent::CLICK_EVENT && event->getDispatcher() == examplesButton) {
- showModal(exampleBrowserWindow);
- newProjectWindow->ResetForm();
- }
-
- }
- }
- PolycodeProjectBrowser *PolycodeFrame::getCurrentProjectBrowser() {
- if(activeProjectFrame) {
- return activeProjectFrame->getActiveTab()->getProjectBrowser();
- } else {
- return NULL;
- }
- }
- void PolycodeFrame::Resize(int x, int y) {
-
- welcomeEntity->setPosition((x-welcomeImage->getWidth()) / 2,
- (y-welcomeImage->getHeight()) / 2);
-
- topBarBg->Resize(x, 45);
- logo->setPosition(x-logo->getWidth()-2, 2);
- resizer->setPosition(x-resizer->getWidth()-1, y-resizer->getHeight()-1);
- consoleSizer->Resize(x,y-45);
-
- modalBlocker->Resize(x, y);
- fileDialogBlocker->Resize(x, y);
-
- if(this->modalChild) {
- modalChild->setPosition((x-modalChild->getWidth())/2.0f, (y-modalChild->getHeight())/2.0f);
- }
-
- UIElement::Resize(x, y);
- }
- ObjectEntry *PolycodeFrame::getFrameConfigForProject(PolycodeProject *project) {
- for(int i=0; i < projectFrames.size(); i++) {
- if(projectFrames[i]->getProject() == project) {
- return projectFrames[i]->getFrameConfig();
- }
- }
- return NULL;
- }
- void PolycodeFrame::removeProjectFrame(PolycodeProject *project) {
- }
- PolycodeProjectFrame *PolycodeFrame::getActiveProjectFrame() {
- return activeProjectFrame;
- }
- PolycodeFrame::~PolycodeFrame() {
-
- }
- UIVSizer *PolycodeFrame::getConsoleSizer() {
- return consoleSizer;
- }
- PolycodeProjectFrame *PolycodeFrame::createProjectFrame(PolycodeProject *project) {
- PolycodeProjectFrame *newProjectFrame = new PolycodeProjectFrame(project, editorManager);
- projectFrames.push_back(newProjectFrame);
- switchToProjectFrame(newProjectFrame);
- return newProjectFrame;
- }
- void PolycodeFrame::switchToProjectFrame(PolycodeProjectFrame *projectFrame) {
- if(projectFrame == activeProjectFrame) {
- return;
- }
- if(activeProjectFrame) {
- consoleSizer->removeTopChild();
- if(editorManager->getCurrentEditor()) {
- activeProjectFrame->lastActiveEditorHolder = editorManager->getCurrentEditor()->getEditorHolder();
- }
- activeProjectFrame->removeAllHandlersForListener(this);
- }
- activeProjectFrame = projectFrame;
- consoleSizer->addTopChild(activeProjectFrame);
- activeProjectFrame->getActiveTab()->getEditorHolder()->setActive(true);
- activeProjectFrame->addEventListener(this, UIEvent::CLOSE_EVENT);
- activeProjectFrame->addEventListener(this, Event::CHANGE_EVENT);
- Resize(getWidth(), getHeight());
- }
- PolycodeProjectFrame *PolycodeFrame::getProjectFrame(PolycodeProject *project) {
- for(int i=0; i < projectFrames.size(); i++) {
- if(projectFrames[i]->getProject() == project) {
- return projectFrames[i];
- }
- }
- return NULL;
- }
- void PolycodeFrame::updateFileSelector() {
- if(activeProjectFrame) {
- activeProjectFrame->getActiveTab()->getEditorHolder()->updateFileSelector();
- }
- }
|