| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481 |
- /*
- 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;
- EditPoint::EditPoint(BezierPoint *point, unsigned int type) : Entity() {
- this->point = point;
- this->type = type;
- processInputEvents = true;
-
- draggingPoint = NULL;
- dragging = false;
- controlHandle1 = new UIImage("Images/bezier_handle.png");
- 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 UIImage("Images/bezier_handle.png");
- 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 UIImage("Images/bezier_point.png");
- 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, 128);
- 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, 128);
- 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/610;
- point->p1.y = controlHandle1->getPosition2D().y/-254;
- point->p2.x = pointHandle->getPosition2D().x/610;
- point->p2.y = pointHandle->getPosition2D().y/-254;
-
- point->p3.x = controlHandle2->getPosition2D().x/610;
- point->p3.y = controlHandle2->getPosition2D().y/-254;
- }
- 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(UIImage *point) {
- if(point->getPosition().x < 0.0)
- point->setPositionX(0.0);
- if(point->getPosition().x > 610.0)
- point->setPositionX(610.0);
- if(point->getPosition().y > 0.0)
- point->setPositionY(0.0);
- if(point->getPosition().y < -254.0)
- point->setPositionY(-254.0);
- }
- void EditPoint::updatePosition() {
- pointHandle->setPosition(610.0*point->p2.x, -254*point->p2.y, 0.0);
- controlHandle1->setPosition(610.0*point->p1.x, -254*point->p1.y, 0.0);
- controlHandle2->setPosition(610.0*point->p3.x, -254*point->p3.y, 0.0);
- }
- EditPoint::~EditPoint() {
- }
- EditCurve::EditCurve(BezierCurve *targetCurve, Color curveColor) : UIElement() {
-
- this->targetCurve = targetCurve;
-
- poly = new Polycode::Polygon();
-
- for(int i=0; i < CURVE_SIZE; i++) {
- poly->addVertex(0.0, 0.0, 0.0);
- }
-
- visMesh = new SceneMesh(Mesh::LINE_STRIP_MESH);
- visMesh->getMesh()->addPolygon(poly);
-
- visMesh->lineSmooth = true;
- visMesh->lineWidth = 2.0;
- addChild(visMesh);
- visMesh->setPosition(0, 254);
- 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, 254);
- }
- }
- 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 = 610.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++) {
- poly->getVertex(i)->set(targetCurve->getPointAt(normInterval * i).x * 610, targetCurve->getPointAt(normInterval * i).y * -254.0, 0.0);
- }
-
- visMesh->getMesh()->arrayDirtyMap[RenderDataArray::VERTEX_DATA_ARRAY] = true;
- }
- EditCurve::~EditCurve() {
- }
- CurveEditor::CurveEditor() : UIWindow("", 750, 300) {
-
- closeOnEscape = true;
-
- bg = new UIImage("Images/curve_editor_bg.png");
- addChild(bg);
- bg->setPosition(160, 63);
- bg->processInputEvents = true;
- bg->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
-
- selectorImage = new UIImage("Images/ScreenEditor/selector.png");
- selectorImage->setColor(0.0, 0.0, 0.0, 0.3);
- addChild(selectorImage);
-
- selectButton = new UIImageButton("Images/ScreenEditor/arrow.png");
- addChild(selectButton);
- selectButton->addEventListener(this, UIEvent::CLICK_EVENT);
- selectButton->setPosition(170, 33);
- addButton = new UIImageButton("Images/arrow_add.png");
- addChild(addButton);
- addButton->addEventListener(this, UIEvent::CLICK_EVENT);
- addButton->setPosition(170 + 32, 33);
- removeButton = new UIImageButton("Images/arrow_remove.png");
- addChild(removeButton);
- removeButton->addEventListener(this, UIEvent::CLICK_EVENT);
- removeButton->setPosition(170 + 64, 33);
-
- selectorImage->setPosition(selectButton->getPosition().x - 4, selectButton->getPosition().y - 4);
- selectedCurve = NULL;
- setMode(0);
-
- treeContainer = new UITreeContainer("boxIcon.png", L"Curves", 145, 280);
- 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("Images/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/610.0;
- pos.y = 1.0-(pos.y/254.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 - 4, selectButton->getPosition().y - 4);
- setMode(0);
- }
- if(event->getDispatcher() == addButton) {
- selectorImage->setPosition(addButton->getPosition().x - 4, addButton->getPosition().y - 4);
- setMode(1);
- }
- if(event->getDispatcher() == removeButton) {
- selectorImage->setPosition(removeButton->getPosition().x - 4, removeButton->getPosition().y - 4);
- 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);
- }
- }
- }
-
- 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("Images/editor_vsplit.png");
- holderBar->addChild(vSplitButton);
- vSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
- hSplitButton = new UIImageButton("Images/editor_hsplit.png");
- holderBar->addChild(hSplitButton);
- hSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
- mergeSplitButton = new UIImageButton("Images/editor_mergesplit.png");
- holderBar->addChild(mergeSplitButton);
- mergeSplitButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- closeFileButton = new UIImageButton("Images/remove_icon.png");
- 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;
- }
- void EditorHolder::setActive(bool val) {
- isActive = val;
- 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::handleEvent(Event *event) {
- if(event->getDispatcher() == this) {
- if(holderBar->visible) {
- setActive(true);
- }
- } else if(event->getDispatcher() == vSplitButton) {
- holderBar->visible = false;
- holderBar->enabled = false;
-
- vSizer = new UIVSizer(getWidth(), getHeight(), getHeight()/2.0, 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;
- }
-
- } else if(event->getDispatcher() == hSplitButton) {
- holderBar->visible = false;
- holderBar->enabled = false;
-
- hSizer = new UIHSizer(getWidth(), getHeight(), getWidth()/2.0, 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;
- }
-
-
- } else if(event->getDispatcher() == currentFileSelector) {
- PolycodeEditor *editor = (PolycodeEditor*) currentFileSelector->getSelectedItem()->data;
- if(currentEditor != editor) {
- setEditor(editor);
- }
-
- } else if(event->getDispatcher() == mergeSplitButton) {
- if(parentHolder) {
- parentHolder->mergeSides(this);
- }
- } 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;
- 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);
- }
- }
-
- setActive(true);
-
- if(vSizer) {
- removeChild(vSizer);
- delete vSizer;
- }
- if(hSizer) {
- removeChild(hSizer);
- delete hSizer;
- }
- delete firstChildHolder;
- delete secondChildHolder;
-
- firstChildHolder = NULL;
- secondChildHolder = NULL;
- vSizer = NULL;
- hSizer = NULL;
-
- 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(PolycodeProject *project, PolycodeEditorManager *editorManager) : UIElement() {
- tabName = "Default";
-
- 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);
- 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;
- }
- 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;
- }
- 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->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 UIRect("Images/tab_bg.png");
- addChild(bgRect);
- bgRect->setColor(1.0, 1.0, 1.0, 0.4);
- bgRect->processInputEvents = true;
- processInputEvents = true;
- bgRect->addEventListener(this, InputEvent::EVENT_MOUSEDOWN);
-
- setWidth(150);
- setHeight(30);
-
- tabLabel = new UILabel(tab->getTabName().toUpperCase(), 16, "section");
- tabLabel->setPosition((getWidth()-tabLabel->getWidth())/2.0, ((getHeight()-tabLabel->getHeight())/2.0) - 3.0);
- addChild(tabLabel);
- }
- void PolycodeTabButton::handleEvent(Event *event) {
- if(event->getDispatcher() == bgRect) {
- dispatchEvent(new Event(), Event::SELECT_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) {
- this->editorManager = editorManager;
- this->project = project;
- lastActiveEditorHolder = NULL;
- tabButtonAnchor = new UIElement();
- addChild(tabButtonAnchor);
- tabButtonAnchor->setPosition(400, -30);
-
- activeTab = NULL;
-
- newTabButton = new UIImageButton("Images/new_tab_button.png");
- tabButtonAnchor->addChild(newTabButton);
- newTabButton->addEventListener(this, UIEvent::CLICK_EVENT);
- addNewTab();
- }
- PolycodeProjectTab *PolycodeProjectFrame::getActiveTab() {
- return activeTab;
- }
- PolycodeProjectTab *PolycodeProjectFrame::addNewTab() {
- PolycodeProjectTab *newTab = new PolycodeProjectTab(project, editorManager);
- tabs.push_back(newTab);
-
- PolycodeTabButton *newTabButton = new PolycodeTabButton(newTab);
- tabButtonAnchor->addChild(newTabButton);
- tabButtons.push_back(newTabButton);
- newTabButton->addEventListener(this, Event::SELECT_EVENT);
- showTab(newTab);
- return newTab;
- }
- 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();
- }
- void PolycodeProjectFrame::restructTabs() {
- int i;
- for(i=0; i < tabButtons.size(); i++) {
- tabButtons[i]->setPosition(i * 155.0, 0.0);
- tabButtons[i]->setActive(tabButtons[i]->getTab()->isActive());
- }
- newTabButton->setPosition((i * 155), 0.0);
- }
- void PolycodeProjectFrame::handleEvent(Event *event) {
- if(event->getEventCode() == UIEvent::CLOSE_EVENT) {
- dispatchEvent(new UIEvent, UIEvent::CLOSE_EVENT);
- } else {
- 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;
- }
- }
- }
- }
- }
- }
- 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("Images/welcome.png");
- welcomeEntity->addChild(welcomeImage);
- welcomeEntity->snapToPixels = true;
-
- newProjectButton = new UIButton("Create A New Project!", 220);
- newProjectButton->setPosition(230,80);
- newProjectButton->addEventListener(this, UIEvent::CLICK_EVENT);
-
- examplesButton = new UIButton("Browse Example Projects!", 220);
- examplesButton->setPosition(460,80);
- 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("Images/barlogo.png");
- addChild(logo);
-
-
- playButton = new UIImageButton("Images/play_button.png");
- addChild(playButton);
- playButton->setPosition(10,4);
- stopButton = new UIImageButton("Images/stop_button.png");
- addChild(stopButton);
- stopButton->setPosition(10,4);
- currentProjectSelector = new UIComboBox(globalMenu, 300);
- currentProjectSelector->addEventListener(this, UIEvent::CHANGE_EVENT);
- addChild(currentProjectSelector);
- currentProjectSelector->setPosition(60, 10);
-
- resizer = new UIImage("Images/corner_resize.png");
- addChild(resizer);
- resizer->setColor(0,0,0,0.4);
-
- modalBlocker = new UIRect(10,10);
- 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("Images/about.png");
- 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);
-
- 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;
- }
- 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;
- }
- void PolycodeFrame::Update() {
- if(willHideModal) {
- hideModal();
- willHideModal = false;
- }
- }
- 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() == 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);
- }
- 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);
- if(activeProjectFrame->lastActiveEditorHolder) {
- activeProjectFrame->lastActiveEditorHolder->setActive(true);
- } else {
- activeProjectFrame->getActiveTab()->getEditorHolder()->setActive(true);
- }
- activeProjectFrame->addEventListener(this, UIEvent::CLOSE_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();
- }
- }
|