When I create ToggleButton it does not fill all area in grid. I think it's because the pressing area is more than viewable area of the button. How can I make these areas equal?
<Grid Grid.Column="0">
<ToggleButton x:Name="ToggleHorizontal"
IsChecked="False"/>
</Grid>
By default toggle button (not only but it too) has touch area around visible border with thickness of 12 px (PhoneTouchTargetOverhang constant, see MSDN). You can see this by editing the style of toggle button in the Blend.
So you can set value of margin in your XAML to -12:
Or you can change this constant to 0 in toggle-button style.
Margin="{StaticResource PhoneTouchTargetOverhang}"
to
Margin="0"
Hope I correctly understood your question and my answer will be helpful
UPD: I think it's easier to set Margin value directly to your toggle button, but if you wish...
Add this to your resource section in page and don't forget to set style to your toggle button:
And your ToggleButton now: