Font Color issue in Mathematica 12Mathematica color schemes for the colorblindFont sizes in graphicsChange Default Font Color of CommandsHow to change the font color and size of tick labels by defaultLine graphics opaqueness issueColor Space issue with GraphicsGraphics Alignment IssueIssue with FrameTick marks in Mathematica 11.3Mathematica 12, supported GPUsMathematica 12.0.0 crashes on second 'Quit[]'

How to verbalise code in Mathematica?

A possible fake AI on Patreon!

function to receive a character input and return date format (with incorrect input)

Stop and Take a Breath!

Sci-fi novel series with instant travel between planets through gates. A river runs through the gates

Was there a Viking Exchange as well as a Columbian one?

What does KSP mean?

Realistic Necromancy?

Any examples of headwear for races with animal ears?

Mac Pro install disk keeps ejecting itself

Why does nature favour the Laplacian?

What is the most expensive material in the world that could be used to create Pun-Pun's lute?

What is the point of Germany's 299 "party seats" in the Bundestag?

What is the strongest case that can be made in favour of the UK regaining some control over fishing policy after Brexit?

How do Bards prepare spells?

Is it possible to dynamically set properties of an `Object` using Apex?

What's the polite way to say "I need to urinate"?

Who is the Umpire in this picture?

How would one muzzle a full grown polar bear in the 13th century?

Why does processed meat contain preservatives, while canned fish needs not?

French for 'It must be my imagination'?

Don’t seats that recline flat defeat the purpose of having seatbelts?

Pulling the rope with one hand is as heavy as with two hands?

Unexpected email from Yorkshire Bank



Font Color issue in Mathematica 12


Mathematica color schemes for the colorblindFont sizes in graphicsChange Default Font Color of CommandsHow to change the font color and size of tick labels by defaultLine graphics opaqueness issueColor Space issue with GraphicsGraphics Alignment IssueIssue with FrameTick marks in Mathematica 11.3Mathematica 12, supported GPUsMathematica 12.0.0 crashes on second 'Quit[]'













1












$begingroup$


TD = 8 + 12 + 12 + 12 + 33 + (61 + 1/4) + (41 + 1/4)/2 + 
15/2 + (18 + 3/4) + (18 + 3/4)/2 + 14/2;
CM = 15/2 + (61 + 1/4) + (41 + 1/4)/2 +
24 + (3 + 3/4) + (18 + 3/4) + (18 + 3/4)/2 + 14/2 + (24 + 3/4) +
9/2;
TP = 2*90;

countsDim1 = CM, TD, TP/(TD + TP + CM)

n = 384 + 179;
labels = Placed[
Row /@ Thread["" <> ToString@# <>
" H" & /@ N[(n countsDim1[[1]]), 5],
N[(n countsDim1[[2]]), 5], Round@N[(n countsDim1)[[3]]]],
"RadialOuter"];
legend = Placed[
SwatchLegend[Automatic,
Row /@ Thread["CM ", "TD ", "TP ",
Row["(", #, , ")"] & /@
Quantity[Round[100 countsDim1], "Percent"]],
LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
FontColor -> Black, FontWeight -> Bold,
LegendMarkerSize -> 26], After, Bottom, Framed];

type = Framed[
PieChart[countsDim1, ChartLabels -> labels, ChartLegends -> legend,
PlotRange -> All,
LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
FontColor -> White, FontWeight -> Bold, PlotTheme -> "Business",
ImageSize -> Medium], Background -> LightGreen]


In Mathematica 11.3 above code would produce a Pie Chart with the percentage of the Legend black. In Mathematica 12, I get the text of the percentage with gray color.



Version 12



Below the same figure with Mathematica 11.3 (albeit without the bold text of the LegendLabel)



Version 11.3



What is different in Mathematica 12?



How can I get the percentage in black color (and bold)?










share|improve this question











$endgroup$
















    1












    $begingroup$


    TD = 8 + 12 + 12 + 12 + 33 + (61 + 1/4) + (41 + 1/4)/2 + 
    15/2 + (18 + 3/4) + (18 + 3/4)/2 + 14/2;
    CM = 15/2 + (61 + 1/4) + (41 + 1/4)/2 +
    24 + (3 + 3/4) + (18 + 3/4) + (18 + 3/4)/2 + 14/2 + (24 + 3/4) +
    9/2;
    TP = 2*90;

    countsDim1 = CM, TD, TP/(TD + TP + CM)

    n = 384 + 179;
    labels = Placed[
    Row /@ Thread["" <> ToString@# <>
    " H" & /@ N[(n countsDim1[[1]]), 5],
    N[(n countsDim1[[2]]), 5], Round@N[(n countsDim1)[[3]]]],
    "RadialOuter"];
    legend = Placed[
    SwatchLegend[Automatic,
    Row /@ Thread["CM ", "TD ", "TP ",
    Row["(", #, , ")"] & /@
    Quantity[Round[100 countsDim1], "Percent"]],
    LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
    FontColor -> Black, FontWeight -> Bold,
    LegendMarkerSize -> 26], After, Bottom, Framed];

    type = Framed[
    PieChart[countsDim1, ChartLabels -> labels, ChartLegends -> legend,
    PlotRange -> All,
    LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
    FontColor -> White, FontWeight -> Bold, PlotTheme -> "Business",
    ImageSize -> Medium], Background -> LightGreen]


    In Mathematica 11.3 above code would produce a Pie Chart with the percentage of the Legend black. In Mathematica 12, I get the text of the percentage with gray color.



    Version 12



    Below the same figure with Mathematica 11.3 (albeit without the bold text of the LegendLabel)



    Version 11.3



    What is different in Mathematica 12?



    How can I get the percentage in black color (and bold)?










    share|improve this question











    $endgroup$














      1












      1








      1





      $begingroup$


      TD = 8 + 12 + 12 + 12 + 33 + (61 + 1/4) + (41 + 1/4)/2 + 
      15/2 + (18 + 3/4) + (18 + 3/4)/2 + 14/2;
      CM = 15/2 + (61 + 1/4) + (41 + 1/4)/2 +
      24 + (3 + 3/4) + (18 + 3/4) + (18 + 3/4)/2 + 14/2 + (24 + 3/4) +
      9/2;
      TP = 2*90;

      countsDim1 = CM, TD, TP/(TD + TP + CM)

      n = 384 + 179;
      labels = Placed[
      Row /@ Thread["" <> ToString@# <>
      " H" & /@ N[(n countsDim1[[1]]), 5],
      N[(n countsDim1[[2]]), 5], Round@N[(n countsDim1)[[3]]]],
      "RadialOuter"];
      legend = Placed[
      SwatchLegend[Automatic,
      Row /@ Thread["CM ", "TD ", "TP ",
      Row["(", #, , ")"] & /@
      Quantity[Round[100 countsDim1], "Percent"]],
      LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
      FontColor -> Black, FontWeight -> Bold,
      LegendMarkerSize -> 26], After, Bottom, Framed];

      type = Framed[
      PieChart[countsDim1, ChartLabels -> labels, ChartLegends -> legend,
      PlotRange -> All,
      LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
      FontColor -> White, FontWeight -> Bold, PlotTheme -> "Business",
      ImageSize -> Medium], Background -> LightGreen]


      In Mathematica 11.3 above code would produce a Pie Chart with the percentage of the Legend black. In Mathematica 12, I get the text of the percentage with gray color.



      Version 12



      Below the same figure with Mathematica 11.3 (albeit without the bold text of the LegendLabel)



      Version 11.3



      What is different in Mathematica 12?



      How can I get the percentage in black color (and bold)?










      share|improve this question











      $endgroup$




      TD = 8 + 12 + 12 + 12 + 33 + (61 + 1/4) + (41 + 1/4)/2 + 
      15/2 + (18 + 3/4) + (18 + 3/4)/2 + 14/2;
      CM = 15/2 + (61 + 1/4) + (41 + 1/4)/2 +
      24 + (3 + 3/4) + (18 + 3/4) + (18 + 3/4)/2 + 14/2 + (24 + 3/4) +
      9/2;
      TP = 2*90;

      countsDim1 = CM, TD, TP/(TD + TP + CM)

      n = 384 + 179;
      labels = Placed[
      Row /@ Thread["" <> ToString@# <>
      " H" & /@ N[(n countsDim1[[1]]), 5],
      N[(n countsDim1[[2]]), 5], Round@N[(n countsDim1)[[3]]]],
      "RadialOuter"];
      legend = Placed[
      SwatchLegend[Automatic,
      Row /@ Thread["CM ", "TD ", "TP ",
      Row["(", #, , ")"] & /@
      Quantity[Round[100 countsDim1], "Percent"]],
      LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
      FontColor -> Black, FontWeight -> Bold,
      LegendMarkerSize -> 26], After, Bottom, Framed];

      type = Framed[
      PieChart[countsDim1, ChartLabels -> labels, ChartLegends -> legend,
      PlotRange -> All,
      LabelStyle -> FontSize -> 26, FontFamily -> "Latin Modern Roman",
      FontColor -> White, FontWeight -> Bold, PlotTheme -> "Business",
      ImageSize -> Medium], Background -> LightGreen]


      In Mathematica 11.3 above code would produce a Pie Chart with the percentage of the Legend black. In Mathematica 12, I get the text of the percentage with gray color.



      Version 12



      Below the same figure with Mathematica 11.3 (albeit without the bold text of the LegendLabel)



      Version 11.3



      What is different in Mathematica 12?



      How can I get the percentage in black color (and bold)?







      graphics version-12






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited 3 hours ago







      Dimitris

















      asked 4 hours ago









      DimitrisDimitris

      2,3621332




      2,3621332




















          2 Answers
          2






          active

          oldest

          votes


















          1












          $begingroup$

          I don't know why it was visualized like that in Mathematica 11.3, but generally speaking, styling can be affected when you plot objects like entities, quantities, etc. instead of their corresponding strings. To be fully in control of the styling, I would suggest converting the quantity to a number.



          I suggest replacing



          Row["(", #, , ")"]


          with



          Row["(", QuantityMagnitude[#], "%)"]





          share|improve this answer









          $endgroup$




















            1












            $begingroup$

            Looks like a bug to me:



            In version 12.0, the typesetting of Quantity objects in TraditionalForm (which is used for legends in Legended expressions) breaks after typesetting a quantity with the same unit in StandardForm. To see this, consider the following example: (use a fresh kernel)



            TraditionalForm@Quantity[3.5, "Percent"]
            Quantity[3.5, "Percent"]
            TraditionalForm@Quantity[3.5, "Percent"]
            TraditionalForm@Quantity[1, "Percent"]


            enter image description here



            As you can see, quantities are typeset differently in TraditionalForm, and the one for TraditionalForm changes after typesetting in StandardForm once. The case of 1 is handled differently for some reason and does not break.



            In 11.3, the typesetting of the TraditionalForm variant does not break after typesetting the StandardForm variant. This is why your example works in 11.3: The style for TraditionalForm does not set the FontColor, while the StandardForm one does (see CurrentValue[StyleDefinitions, "QuantityPanel"], which is only used for StandardForm). That this works seems like a lucky coincidence, so I would suggest to use the method from @C.E.'s answer anyway, even if this gets fixed.



            Tracking down the issue



            The issue is caused by a change to the caching used for quantity typesetting:



            (* cache lookup in 11.3 typesetting code for Quantity *)
            QuantityUnits`QuantityBox[
            Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form:StandardForm]
            ] :=
            Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]

            (* cache lookup in 12.0 typesetting code for Quantity *)
            QuantityUnits`QuantityBox[
            Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form_:StandardForm]
            ] :=
            Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]


            Note the change from form:StandardForm to form_:StandardForm - this extends the caching from StandardForm to all forms. The reason I think this is a bug is that this is the only definition of QuantityBox that defaults form to anything (all the others require an explicit form to be given), which suggests someone "fixed" a typo.



            The issue with the caching code is that it ignores form when performing the cache lookup. Writing to the cache still requires StandardForm (here, the form:StandardForm pattern is still present in 12.0). The code was already questionable in 11.3 (since the caching partially supports forms other than StandardForm), but this was not an issue since it was only ever called with StandardForm.






            share|improve this answer









            $endgroup$













              Your Answer








              StackExchange.ready(function()
              var channelOptions =
              tags: "".split(" "),
              id: "387"
              ;
              initTagRenderer("".split(" "), "".split(" "), channelOptions);

              StackExchange.using("externalEditor", function()
              // Have to fire editor after snippets, if snippets enabled
              if (StackExchange.settings.snippets.snippetsEnabled)
              StackExchange.using("snippets", function()
              createEditor();
              );

              else
              createEditor();

              );

              function createEditor()
              StackExchange.prepareEditor(
              heartbeatType: 'answer',
              autoActivateHeartbeat: false,
              convertImagesToLinks: false,
              noModals: true,
              showLowRepImageUploadWarning: true,
              reputationToPostImages: null,
              bindNavPrevention: true,
              postfix: "",
              imageUploader:
              brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
              contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
              allowUrls: true
              ,
              onDemand: true,
              discardSelector: ".discard-answer"
              ,immediatelyShowMarkdownHelp:true
              );



              );













              draft saved

              draft discarded


















              StackExchange.ready(
              function ()
              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f197228%2ffont-color-issue-in-mathematica-12%23new-answer', 'question_page');

              );

              Post as a guest















              Required, but never shown

























              2 Answers
              2






              active

              oldest

              votes








              2 Answers
              2






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes









              1












              $begingroup$

              I don't know why it was visualized like that in Mathematica 11.3, but generally speaking, styling can be affected when you plot objects like entities, quantities, etc. instead of their corresponding strings. To be fully in control of the styling, I would suggest converting the quantity to a number.



              I suggest replacing



              Row["(", #, , ")"]


              with



              Row["(", QuantityMagnitude[#], "%)"]





              share|improve this answer









              $endgroup$

















                1












                $begingroup$

                I don't know why it was visualized like that in Mathematica 11.3, but generally speaking, styling can be affected when you plot objects like entities, quantities, etc. instead of their corresponding strings. To be fully in control of the styling, I would suggest converting the quantity to a number.



                I suggest replacing



                Row["(", #, , ")"]


                with



                Row["(", QuantityMagnitude[#], "%)"]





                share|improve this answer









                $endgroup$















                  1












                  1








                  1





                  $begingroup$

                  I don't know why it was visualized like that in Mathematica 11.3, but generally speaking, styling can be affected when you plot objects like entities, quantities, etc. instead of their corresponding strings. To be fully in control of the styling, I would suggest converting the quantity to a number.



                  I suggest replacing



                  Row["(", #, , ")"]


                  with



                  Row["(", QuantityMagnitude[#], "%)"]





                  share|improve this answer









                  $endgroup$



                  I don't know why it was visualized like that in Mathematica 11.3, but generally speaking, styling can be affected when you plot objects like entities, quantities, etc. instead of their corresponding strings. To be fully in control of the styling, I would suggest converting the quantity to a number.



                  I suggest replacing



                  Row["(", #, , ")"]


                  with



                  Row["(", QuantityMagnitude[#], "%)"]






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered 1 hour ago









                  C. E.C. E.

                  51.5k3101207




                  51.5k3101207





















                      1












                      $begingroup$

                      Looks like a bug to me:



                      In version 12.0, the typesetting of Quantity objects in TraditionalForm (which is used for legends in Legended expressions) breaks after typesetting a quantity with the same unit in StandardForm. To see this, consider the following example: (use a fresh kernel)



                      TraditionalForm@Quantity[3.5, "Percent"]
                      Quantity[3.5, "Percent"]
                      TraditionalForm@Quantity[3.5, "Percent"]
                      TraditionalForm@Quantity[1, "Percent"]


                      enter image description here



                      As you can see, quantities are typeset differently in TraditionalForm, and the one for TraditionalForm changes after typesetting in StandardForm once. The case of 1 is handled differently for some reason and does not break.



                      In 11.3, the typesetting of the TraditionalForm variant does not break after typesetting the StandardForm variant. This is why your example works in 11.3: The style for TraditionalForm does not set the FontColor, while the StandardForm one does (see CurrentValue[StyleDefinitions, "QuantityPanel"], which is only used for StandardForm). That this works seems like a lucky coincidence, so I would suggest to use the method from @C.E.'s answer anyway, even if this gets fixed.



                      Tracking down the issue



                      The issue is caused by a change to the caching used for quantity typesetting:



                      (* cache lookup in 11.3 typesetting code for Quantity *)
                      QuantityUnits`QuantityBox[
                      Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form:StandardForm]
                      ] :=
                      Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]

                      (* cache lookup in 12.0 typesetting code for Quantity *)
                      QuantityUnits`QuantityBox[
                      Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form_:StandardForm]
                      ] :=
                      Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]


                      Note the change from form:StandardForm to form_:StandardForm - this extends the caching from StandardForm to all forms. The reason I think this is a bug is that this is the only definition of QuantityBox that defaults form to anything (all the others require an explicit form to be given), which suggests someone "fixed" a typo.



                      The issue with the caching code is that it ignores form when performing the cache lookup. Writing to the cache still requires StandardForm (here, the form:StandardForm pattern is still present in 12.0). The code was already questionable in 11.3 (since the caching partially supports forms other than StandardForm), but this was not an issue since it was only ever called with StandardForm.






                      share|improve this answer









                      $endgroup$

















                        1












                        $begingroup$

                        Looks like a bug to me:



                        In version 12.0, the typesetting of Quantity objects in TraditionalForm (which is used for legends in Legended expressions) breaks after typesetting a quantity with the same unit in StandardForm. To see this, consider the following example: (use a fresh kernel)



                        TraditionalForm@Quantity[3.5, "Percent"]
                        Quantity[3.5, "Percent"]
                        TraditionalForm@Quantity[3.5, "Percent"]
                        TraditionalForm@Quantity[1, "Percent"]


                        enter image description here



                        As you can see, quantities are typeset differently in TraditionalForm, and the one for TraditionalForm changes after typesetting in StandardForm once. The case of 1 is handled differently for some reason and does not break.



                        In 11.3, the typesetting of the TraditionalForm variant does not break after typesetting the StandardForm variant. This is why your example works in 11.3: The style for TraditionalForm does not set the FontColor, while the StandardForm one does (see CurrentValue[StyleDefinitions, "QuantityPanel"], which is only used for StandardForm). That this works seems like a lucky coincidence, so I would suggest to use the method from @C.E.'s answer anyway, even if this gets fixed.



                        Tracking down the issue



                        The issue is caused by a change to the caching used for quantity typesetting:



                        (* cache lookup in 11.3 typesetting code for Quantity *)
                        QuantityUnits`QuantityBox[
                        Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form:StandardForm]
                        ] :=
                        Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]

                        (* cache lookup in 12.0 typesetting code for Quantity *)
                        QuantityUnits`QuantityBox[
                        Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form_:StandardForm]
                        ] :=
                        Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]


                        Note the change from form:StandardForm to form_:StandardForm - this extends the caching from StandardForm to all forms. The reason I think this is a bug is that this is the only definition of QuantityBox that defaults form to anything (all the others require an explicit form to be given), which suggests someone "fixed" a typo.



                        The issue with the caching code is that it ignores form when performing the cache lookup. Writing to the cache still requires StandardForm (here, the form:StandardForm pattern is still present in 12.0). The code was already questionable in 11.3 (since the caching partially supports forms other than StandardForm), but this was not an issue since it was only ever called with StandardForm.






                        share|improve this answer









                        $endgroup$















                          1












                          1








                          1





                          $begingroup$

                          Looks like a bug to me:



                          In version 12.0, the typesetting of Quantity objects in TraditionalForm (which is used for legends in Legended expressions) breaks after typesetting a quantity with the same unit in StandardForm. To see this, consider the following example: (use a fresh kernel)



                          TraditionalForm@Quantity[3.5, "Percent"]
                          Quantity[3.5, "Percent"]
                          TraditionalForm@Quantity[3.5, "Percent"]
                          TraditionalForm@Quantity[1, "Percent"]


                          enter image description here



                          As you can see, quantities are typeset differently in TraditionalForm, and the one for TraditionalForm changes after typesetting in StandardForm once. The case of 1 is handled differently for some reason and does not break.



                          In 11.3, the typesetting of the TraditionalForm variant does not break after typesetting the StandardForm variant. This is why your example works in 11.3: The style for TraditionalForm does not set the FontColor, while the StandardForm one does (see CurrentValue[StyleDefinitions, "QuantityPanel"], which is only used for StandardForm). That this works seems like a lucky coincidence, so I would suggest to use the method from @C.E.'s answer anyway, even if this gets fixed.



                          Tracking down the issue



                          The issue is caused by a change to the caching used for quantity typesetting:



                          (* cache lookup in 11.3 typesetting code for Quantity *)
                          QuantityUnits`QuantityBox[
                          Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form:StandardForm]
                          ] :=
                          Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]

                          (* cache lookup in 12.0 typesetting code for Quantity *)
                          QuantityUnits`QuantityBox[
                          Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form_:StandardForm]
                          ] :=
                          Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]


                          Note the change from form:StandardForm to form_:StandardForm - this extends the caching from StandardForm to all forms. The reason I think this is a bug is that this is the only definition of QuantityBox that defaults form to anything (all the others require an explicit form to be given), which suggests someone "fixed" a typo.



                          The issue with the caching code is that it ignores form when performing the cache lookup. Writing to the cache still requires StandardForm (here, the form:StandardForm pattern is still present in 12.0). The code was already questionable in 11.3 (since the caching partially supports forms other than StandardForm), but this was not an issue since it was only ever called with StandardForm.






                          share|improve this answer









                          $endgroup$



                          Looks like a bug to me:



                          In version 12.0, the typesetting of Quantity objects in TraditionalForm (which is used for legends in Legended expressions) breaks after typesetting a quantity with the same unit in StandardForm. To see this, consider the following example: (use a fresh kernel)



                          TraditionalForm@Quantity[3.5, "Percent"]
                          Quantity[3.5, "Percent"]
                          TraditionalForm@Quantity[3.5, "Percent"]
                          TraditionalForm@Quantity[1, "Percent"]


                          enter image description here



                          As you can see, quantities are typeset differently in TraditionalForm, and the one for TraditionalForm changes after typesetting in StandardForm once. The case of 1 is handled differently for some reason and does not break.



                          In 11.3, the typesetting of the TraditionalForm variant does not break after typesetting the StandardForm variant. This is why your example works in 11.3: The style for TraditionalForm does not set the FontColor, while the StandardForm one does (see CurrentValue[StyleDefinitions, "QuantityPanel"], which is only used for StandardForm). That this works seems like a lucky coincidence, so I would suggest to use the method from @C.E.'s answer anyway, even if this gets fixed.



                          Tracking down the issue



                          The issue is caused by a change to the caching used for quantity typesetting:



                          (* cache lookup in 11.3 typesetting code for Quantity *)
                          QuantityUnits`QuantityBox[
                          Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form:StandardForm]
                          ] :=
                          Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]

                          (* cache lookup in 12.0 typesetting code for Quantity *)
                          QuantityUnits`QuantityBox[
                          Quantity[n_, unit_?QuantityUnits`Private`UnitDisplayCacheContainsQ], form_:StandardForm]
                          ] :=
                          Quiet[QuantityUnits`Private`getUnitDisplayForm[unit, n, form], Part::partw]


                          Note the change from form:StandardForm to form_:StandardForm - this extends the caching from StandardForm to all forms. The reason I think this is a bug is that this is the only definition of QuantityBox that defaults form to anything (all the others require an explicit form to be given), which suggests someone "fixed" a typo.



                          The issue with the caching code is that it ignores form when performing the cache lookup. Writing to the cache still requires StandardForm (here, the form:StandardForm pattern is still present in 12.0). The code was already questionable in 11.3 (since the caching partially supports forms other than StandardForm), but this was not an issue since it was only ever called with StandardForm.







                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered 18 mins ago









                          Lukas LangLukas Lang

                          7,47011032




                          7,47011032



























                              draft saved

                              draft discarded
















































                              Thanks for contributing an answer to Mathematica Stack Exchange!


                              • Please be sure to answer the question. Provide details and share your research!

                              But avoid


                              • Asking for help, clarification, or responding to other answers.

                              • Making statements based on opinion; back them up with references or personal experience.

                              Use MathJax to format equations. MathJax reference.


                              To learn more, see our tips on writing great answers.




                              draft saved


                              draft discarded














                              StackExchange.ready(
                              function ()
                              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmathematica.stackexchange.com%2fquestions%2f197228%2ffont-color-issue-in-mathematica-12%23new-answer', 'question_page');

                              );

                              Post as a guest















                              Required, but never shown





















































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown

































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown







                              Popular posts from this blog

                              Constantinus Vanšenkin Nexus externi | Tabula navigationisБольшая российская энциклопедияAmplifica

                              Montigny (Ligerula) Nexus interni Nexus externi | Tabula navigationisGeoNames45214Amplifica

                              Gaius Norbanus Flaccus (consul 38 a.C.n.) Index De gente | De cursu honorum | Notae | Fontes | Si vis plura legere | Tabula navigationisHic legere potes