Key graph features (#704)
* Added IGraphAnalyzer * Key Graph Features called and getting returned to the client. To do put all strings into the Equation object * Updated UpdateKeyGraphFeatures to add function analysis data to all properties in Equation object * Update KGF when variables are updated * Key graph features ui started * Added MathRichEditBox and started hooking up key graph features to the UI * Updated EquationViewModel to include parity and periodicity * Updated key graph features to update the EquationViewModel * updated key graph features to display more values * Key graph features populating uing MathRichEdit mode * moved KeyGraphFeatures control to GraphingCalculator.xaml * Use MathML formatting instead of MathRichEdit for strings passed back from the engine * cleaned up project targeting and equation.h comments * Updated equation edit box to populate for KeyGraphFeatures * Fixed vcxproj files to have the correct targeting and certificates. KGF Title strings moved to x:Uid instead of the code behind * Updated per PR feedback * Update MathRichEditBox to detect if the string is a mathml string and use the appropriate set method to set the text * fixed the issue where parity, periodicity and monotonicity could be set with an old value if the next one is empty * KGF control UI adjustments and error handling * Error control updates * Error handling added when analysis fails * fixed alignment on rich edit boxes * Add monotonicity direction into the mathml string and only have 1 richeditbox * Set hover state on KGF EquationEditBox to change button opacity and fixed spacing in Monotonicity RichEditBox * remove sideload package certificate info VS added * updated logic for setting error strings to be in the viewmodel * Updated KeyGraphFeatures to populate dynamically using a ListView and TemplateSelector * Update periodicity to not show if it isn't supported * Fixed issue where y-intercept was using the x-intercept value * Remove ItemsControl ItemsContainerStyle * Updated per pr feedback. Fixed bug where analysis error would not reset * Update MathRichEdit box to remove selection when focus is lost * Updated mathrichedit to get LAF access for Dev, Release and Graphing projects * Remove OnLostFocus in MathRichEdit, Change KGF ItemsControl back to ListView * Clean up styles for KGF and ensure the match the comps * Moved formatoptions logic to the Grapher constructor and reverted LineColor.Text resource that was mistakenly taken out * Add copyright header to KGF Files * fixed issue where asymptote values were not populating * Disable KGF button when there is no equation. Fixed issue where equation populated in a new equationtextbox after the previous one was deleted * Removed formatoptions testing lines used for debugging
This commit is contained in:
		| @@ -20,13 +20,12 @@ using namespace Windows::UI::Xaml::Input; | ||||
| using namespace Windows::UI::Xaml::Controls::Primitives; | ||||
|  | ||||
| DEPENDENCY_PROPERTY_INITIALIZATION(EquationTextBox, EquationColor); | ||||
| DEPENDENCY_PROPERTY_INITIALIZATION(EquationTextBox, KeyGraphFeaturesContent); | ||||
| DEPENDENCY_PROPERTY_INITIALIZATION(EquationTextBox, ColorChooserFlyout); | ||||
|  | ||||
| void EquationTextBox::OnApplyTemplate() | ||||
| { | ||||
|     m_equationButton = dynamic_cast<Button ^>(GetTemplateChild("EquationButton")); | ||||
|     m_richEditBox = dynamic_cast<RichEditBox ^>(GetTemplateChild("EquationTextBox")); | ||||
|     m_richEditBox = dynamic_cast<MathRichEditBox ^>(GetTemplateChild("EquationTextBox")); | ||||
|     m_deleteButton = dynamic_cast<Button ^>(GetTemplateChild("DeleteButton")); | ||||
|     m_removeButton = dynamic_cast<Button ^>(GetTemplateChild("RemoveButton")); | ||||
|     m_functionButton = dynamic_cast<Button ^>(GetTemplateChild("FunctionButton")); | ||||
| @@ -34,7 +33,6 @@ void EquationTextBox::OnApplyTemplate() | ||||
|  | ||||
|     if (m_richEditBox != nullptr) | ||||
|     { | ||||
|         m_richEditBox->Loaded += ref new RoutedEventHandler(this, &EquationTextBox::OnRichEditBoxLoaded); | ||||
|         m_richEditBox->GotFocus += ref new RoutedEventHandler(this, &EquationTextBox::OnRichEditBoxGotFocus); | ||||
|         m_richEditBox->LostFocus += ref new RoutedEventHandler(this, &EquationTextBox::OnRichEditBoxLostFocus); | ||||
|         m_richEditBox->TextChanged += ref new RoutedEventHandler(this, &EquationTextBox::OnRichEditBoxTextChanged); | ||||
| @@ -64,6 +62,7 @@ void EquationTextBox::OnApplyTemplate() | ||||
|     if (m_functionButton != nullptr) | ||||
|     { | ||||
|         m_functionButton->Click += ref new RoutedEventHandler(this, &EquationTextBox::OnFunctionButtonClicked); | ||||
|         m_functionButton->IsEnabled = false; | ||||
|     } | ||||
|  | ||||
|     if (ColorChooserFlyout != nullptr) | ||||
| @@ -104,6 +103,10 @@ void EquationTextBox::OnKeyDown(KeyRoutedEventArgs ^ e) | ||||
|     if (e->Key == VirtualKey::Enter) | ||||
|     { | ||||
|         EquationSubmitted(this, ref new RoutedEventArgs()); | ||||
|         if (m_functionButton && m_richEditBox->MathText != L"") | ||||
|         { | ||||
|             m_functionButton->IsEnabled = true; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -112,6 +115,10 @@ void EquationTextBox::OnLostFocus(RoutedEventArgs ^ e) | ||||
|     if (!m_richEditBox->ContextFlyout->IsOpen) | ||||
|     { | ||||
|         EquationSubmitted(this, ref new RoutedEventArgs()); | ||||
|         if (m_functionButton && m_richEditBox->MathText != L"") | ||||
|         { | ||||
|             m_functionButton->IsEnabled = true; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -128,15 +135,6 @@ void EquationTextBox::OnColorFlyoutClosed(Object ^ sender, Object ^ e) | ||||
|     UpdateCommonVisualState(); | ||||
| } | ||||
|  | ||||
| void EquationTextBox::OnRichEditBoxLoaded(Object ^ sender, RoutedEventArgs ^ e) | ||||
| { | ||||
|     LimitedAccessFeatures::TryUnlockFeature( | ||||
|         "com.microsoft.windows.richeditmath", | ||||
|         "H6wflFFz3gkOsAHtG/D9Tg==", | ||||
|         "8wekyb3d8bbwe has registered their use of com.microsoft.windows.richeditmath with Microsoft and agrees to the terms of use."); | ||||
|     m_richEditBox->TextDocument->SetMathMode(::RichEditMathMode::MathOnly); | ||||
| } | ||||
|  | ||||
| void EquationTextBox::OnRichEditBoxTextChanged(Object ^ sender, RoutedEventArgs ^ e) | ||||
| { | ||||
|     UpdateDeleteButtonVisualState(); | ||||
| @@ -163,17 +161,32 @@ void EquationTextBox::OnDeleteButtonClicked(Object ^ sender, RoutedEventArgs ^ e | ||||
| { | ||||
|     if (m_richEditBox != nullptr) | ||||
|     { | ||||
|         m_richEditBox->TextDocument->SetMath(L""); | ||||
|         m_richEditBox->MathText = L""; | ||||
|         if (m_functionButton) | ||||
|         { | ||||
|             m_functionButton->IsEnabled = false; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| void EquationTextBox::OnEquationButtonClicked(Object ^ sender, RoutedEventArgs ^ e) | ||||
| { | ||||
|     EquationButtonClicked(this, ref new RoutedEventArgs()); | ||||
| } | ||||
|  | ||||
| void EquationTextBox::OnRemoveButtonClicked(Object ^ sender, RoutedEventArgs ^ e) | ||||
| { | ||||
|     if (m_richEditBox != nullptr) | ||||
|     { | ||||
|         m_richEditBox->MathText = L""; | ||||
|     } | ||||
|  | ||||
|     RemoveButtonClicked(this, ref new RoutedEventArgs()); | ||||
|  | ||||
|     if (m_functionButton) | ||||
|     { | ||||
|         m_functionButton->IsEnabled = false; | ||||
|     } | ||||
| } | ||||
|  | ||||
| void EquationTextBox::OnColorChooserButtonClicked(Object ^ sender, RoutedEventArgs ^ e) | ||||
| @@ -186,10 +199,7 @@ void EquationTextBox::OnColorChooserButtonClicked(Object ^ sender, RoutedEventAr | ||||
|  | ||||
| void EquationTextBox::OnFunctionButtonClicked(Object ^ sender, RoutedEventArgs ^ e) | ||||
| { | ||||
|     auto equationViewModel = static_cast<EquationViewModel ^>(DataContext); | ||||
|     equationViewModel->KeyGraphFeaturesVisibility = | ||||
|         (equationViewModel->KeyGraphFeaturesVisibility == ::Visibility::Collapsed) ? ::Visibility::Visible : ::Visibility::Collapsed; | ||||
|     UpdateCommonVisualState(); | ||||
|     KeyGraphFeaturesButtonClicked(this, ref new RoutedEventArgs()); | ||||
| } | ||||
|  | ||||
| void EquationTextBox::UpdateDeleteButtonVisualState() | ||||
| @@ -239,7 +249,7 @@ Platform::String ^ EquationTextBox::GetEquationText() | ||||
|             range->CharacterFormat->Underline = UnderlineType::None; | ||||
|         } | ||||
|  | ||||
|         m_richEditBox->TextDocument->GetMath(&text); | ||||
|         text = m_richEditBox->MathText; | ||||
|     } | ||||
|  | ||||
|     return text; | ||||
| @@ -249,7 +259,7 @@ void EquationTextBox::SetEquationText(Platform::String ^ equationText) | ||||
| { | ||||
|     if (m_richEditBox != nullptr) | ||||
|     { | ||||
|         m_richEditBox->TextDocument->SetMath(equationText); | ||||
|         m_richEditBox->MathText = equationText; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -259,7 +269,7 @@ bool EquationTextBox::ShouldDeleteButtonBeVisible() | ||||
|  | ||||
|     if (m_richEditBox != nullptr) | ||||
|     { | ||||
|         m_richEditBox->TextDocument->GetMath(&text); | ||||
|         text = m_richEditBox->MathText; | ||||
|     } | ||||
|     return (!text->IsEmpty() && m_isFocused); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user