Skip to main content

output formatting - Continuous background color of adjacent cells



I'm trying to make continuous blocks of cells so that their background colors are the same, but without breaks of white space between them.


E.g.


enter image description here


After some recent digging, I found the option "Show Expression", which converts the cell to its explicit contents that Mathematica can interpret. For example, the third cell in the image can be created by writing


CellPrint[
Cell["Can we make all",
"Text",
Background->RGBColor[0.87,0.94,1]
]
]


Showing the expression gives more information than I need, which I've omitted in this example. (Things like CellChangeTimes and expression for symbols like the apostrophes. There was also an option specifying the grouping.)


I'm wondering if there's a simple way to use this code to my advantage so I can format the cells so that the line break between stays the same color.


I realize that with text, I can just start a new paragraph by hitting Return a few times, but I'm trying to include examples of Mathematica code for plots and the like.


Edit: Using Stephen's suggestion from the comments, I'm running into some minor issues with my graphics, as in the pic below. A quick fix is to add Background->White where appropriate. The top cell shows what happens when this option is left out, and the bottom shows when it's applied to GraphicsRow. Another has to be added elsewhere (in my case, to Pane) to remove the blue frame.


enter image description here



Answer



Here's one possible way of doing this.


Type some text into 2 successive text cells, then select the cell brackets, open the option inspector (Format / Option Inspector ...) and alter the values displayed at Cell Options / Display Options / CellMargins.


For instance, if the 2 text items are "Hello" and "World", then the resulting Cell expressions might be (Cell / Show Expression)



Cell["Hello", "Text", CellMargins->{{66, 10}, {0, 0}},
Background->RGBColor[0.87, 0.94, 1]]

and


Cell["World", "Text", CellMargins->{{66, 10}, {0, 0}}, 
Background->RGBColor[0.87, 0.94, 1]]

where I have set the top and bottom margins both to be 0.


Comments

Popular posts from this blog

functions - Get leading series expansion term?

Given a function f[x] , I would like to have a function leadingSeries that returns just the leading term in the series around x=0 . For example: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x)] x and leadingSeries[(1/x + 2 + (1 - 1/x^3)/4)/(4 + x)] -(1/(16 x^3)) Is there such a function in Mathematica? Or maybe one can implement it efficiently? EDIT I finally went with the following implementation, based on Carl Woll 's answer: lds[ex_,x_]:=( (ex/.x->(x+O[x]^2))/.SeriesData[U_,Z_,L_List,Mi_,Ma_,De_]:>SeriesData[U,Z,{L[[1]]},Mi,Mi+1,De]//Quiet//Normal) The advantage is, that this one also properly works with functions whose leading term is a constant: lds[Exp[x],x] 1 Answer Update 1 Updated to eliminate SeriesData and to not return additional terms Perhaps you could use: leadingSeries[expr_, x_] := Normal[expr /. x->(x+O[x]^2) /. a_List :> Take[a, 1]] Then for your examples: leadingSeries[(1/x + 2)/(4 + 1/x^2 + x), x] leadingSeries[Exp[x], x] leadingSeries[(1/x + 2 + (1 - 1/x...

How to thread a list

I have data in format data = {{a1, a2}, {b1, b2}, {c1, c2}, {d1, d2}} Tableform: I want to thread it to : tdata = {{{a1, b1}, {a2, b2}}, {{a1, c1}, {a2, c2}}, {{a1, d1}, {a2, d2}}} Tableform: And I would like to do better then pseudofunction[n_] := Transpose[{data2[[1]], data2[[n]]}]; SetAttributes[pseudofunction, Listable]; Range[2, 4] // pseudofunction Here is my benchmark data, where data3 is normal sample of real data. data3 = Drop[ExcelWorkBook[[Column1 ;; Column4]], None, 1]; data2 = {a #, b #, c #, d #} & /@ Range[1, 10^5]; data = RandomReal[{0, 1}, {10^6, 4}]; Here is my benchmark code kptnw[list_] := Transpose[{Table[First@#, {Length@# - 1}], Rest@#}, {3, 1, 2}] &@list kptnw2[list_] := Transpose[{ConstantArray[First@#, Length@# - 1], Rest@#}, {3, 1, 2}] &@list OleksandrR[list_] := Flatten[Outer[List, List@First[list], Rest[list], 1], {{2}, {1, 4}}] paradox2[list_] := Partition[Riffle[list[[1]], #], 2] & /@ Drop[list, 1] RM[list_] := FoldList[Transpose[{First@li...

front end - keyboard shortcut to invoke Insert new matrix

I frequently need to type in some matrices, and the menu command Insert > Table/Matrix > New... allows matrices with lines drawn between columns and rows, which is very helpful. I would like to make a keyboard shortcut for it, but cannot find the relevant frontend token command (4209405) for it. Since the FullForm[] and InputForm[] of matrices with lines drawn between rows and columns is the same as those without lines, it's hard to do this via 3rd party system-wide text expanders (e.g. autohotkey or atext on mac). How does one assign a keyboard shortcut for the menu item Insert > Table/Matrix > New... , preferably using only mathematica? Thanks! Answer In the MenuSetup.tr (for linux located in the $InstallationDirectory/SystemFiles/FrontEnd/TextResources/X/ directory), I changed the line MenuItem["&New...", "CreateGridBoxDialog"] to read MenuItem["&New...", "CreateGridBoxDialog", MenuKey["m", Modifiers-...