From adea0ad0ee8cd4a85b3d51689daabedf7a4e3393 Mon Sep 17 00:00:00 2001 From: denz1994 Date: Tue, 15 May 2018 09:05:25 -0400 Subject: [PATCH] Layout of Panels/Nodes refactored for TwoSpringView. #253 #256. --- js/common/view/OneSpringScreenView.js | 4 +-- js/common/view/TwoSpringScreenView.js | 46 +++++++++++++++------------ 2 files changed, 26 insertions(+), 24 deletions(-) diff --git a/js/common/view/OneSpringScreenView.js b/js/common/view/OneSpringScreenView.js index 7e339d92..43bbc13c 100644 --- a/js/common/view/OneSpringScreenView.js +++ b/js/common/view/OneSpringScreenView.js @@ -188,7 +188,7 @@ define( function( require ) { align: 'top' } ); - // Adding Buttons to scene graph + // Adding system controls and energy graph to scene graph this.addChild( springSystemControlsNode ); this.addChild( this.energyGraphNode ); @@ -205,8 +205,6 @@ define( function( require ) { // Adjust the floating panels to the visibleBounds of the screen. this.visibleBoundsProperty.link( function( visibleBounds ) { - //REVIEW: Lots of layout here. Can we use things like AlignBox/HBox/VBox to simplify? Might be worth collaboration. - //REVIEW: How much of this can be shared with TwoSpringScreenView (and moved to SpringScreenView?) self.panelRightSpacing = visibleBounds.right - self.spacing; // Alignment of layout diff --git a/js/common/view/TwoSpringScreenView.js b/js/common/view/TwoSpringScreenView.js index 8dee7719..600be65a 100644 --- a/js/common/view/TwoSpringScreenView.js +++ b/js/common/view/TwoSpringScreenView.js @@ -43,10 +43,7 @@ define( function( require ) { this.springHangerNode = new SpringHangerNode( model.springs, this.modelViewTransform, - tandem.createTandem( 'springHangerNode' ), { - centerX: this.modelViewTransform.modelToViewX( - model.firstSpring.positionProperty.value.distance( model.secondSpring.positionProperty.value ) ) * 4.7 - } ); + tandem.createTandem( 'springHangerNode' ) ); var leftSpring = this.model.firstSpring; var rightSpring = this.model.secondSpring; @@ -68,8 +65,8 @@ define( function( require ) { // Spring Constant Control Panels var minMaxLabels = [ - new Text( smallString, { font: MassesAndSpringsConstants.LABEL_FONT, maxWidth:40 } ), - new Text( largeString, { font: MassesAndSpringsConstants.LABEL_FONT, maxWidth:40 } ) + new Text( smallString, { font: MassesAndSpringsConstants.LABEL_FONT, maxWidth: 40 } ), + new Text( largeString, { font: MassesAndSpringsConstants.LABEL_FONT, maxWidth: 40 } ) ]; // @public {SpringConstantPanel} @@ -125,16 +122,21 @@ define( function( require ) { movableLineNode.reset(); } ); - // Adding all of the nodes to the scene graph - this.addChild( this.springHangerNode ); - - // Adding Panels to scene graph - this.addChild( this.firstSpringConstantControlPanel ); - this.addChild( this.secondSpringConstantControlPanel ); + // Contains Panels/Nodes that hover near the spring system at the center of the screen. + var springSystemControlsNode = new HBox( { + children: [ + this.firstSpringConstantControlPanel, + this.firstSpringStopperButtonNode, + this.springHangerNode, + this.secondSpringStopperButtonNode, + this.secondSpringConstantControlPanel + ], + spacing: this.spacing, + align: 'top' + } ); - // Adding Buttons to scene graph - this.addChild( this.firstSpringStopperButtonNode ); - this.addChild( this.secondSpringStopperButtonNode ); + // Adding system controls to scene graph + this.addChild( springSystemControlsNode ); // Reference lines from indicator visibility box this.addChild( firstNaturalLengthLineNode ); @@ -143,18 +145,20 @@ define( function( require ) { this.addChild( this.massLayer ); this.addChild( this.toolsLayer ); + // {Number} Used in determining springSystemControlsNode's placement + var distanceBetweenSprings = (self.modelViewTransform.modelToViewX( + model.firstSpring.positionProperty.value.distance( model.secondSpring.positionProperty.value ) ) / 2); + var leftSpringXPosition = self.modelViewTransform.modelToViewX( model.firstSpring.positionProperty.value.x ); + // Adjust the floating panels to the visibleBounds of the screen. this.visibleBoundsProperty.link( function( visibleBounds ) { // Update the bounds of view elements self.panelRightSpacing = visibleBounds.right - self.spacing; - //REVIEW: Lots of layout here. Can we use things like AlignBox/HBox/VBox to simplify? Might be worth collaboration. - //REVIEW: How much of this can be shared with OneSpringScreenView (and moved to SpringScreenView?) - self.springHangerNode.top = model.firstSpring.positionProperty.value.y + self.spacing; - self.gravityAndDampingControlNode.right = self.panelRightSpacing; - self.toolboxPanel.right = self.panelRightSpacing; - self.resetAllButton.right = self.panelRightSpacing; + // Alignment of layout + springSystemControlsNode.centerX = leftSpringXPosition + distanceBetweenSprings; + springSystemControlsNode.top = visibleBounds.top + self.spacing; self.simControlHBox.rightBottom = visibleBounds.rightBottom.minus( new Vector2( self.spacing, self.spacing ) ); // Adjusting drag bounds of draggable objects based on visible bounds.