A simple way to define and render UI specs on top of your Android UI.
Enclose the target UI with a DesignSpecFrameLayout
, usually the root of your view hierarchy.
Get the associated DesignSpec
instance with getDesignSpec
and then you can:
setBaselineGridVisible(boolean)
.setBaselineGridCellSize(int)
.setBaselineGridColor(int)
.setKeylinesVisible(boolean)
.setKeylinesColor(int)
.addKeyline(int, From)
.setSpacingsVisible(boolean)
.setSpacingsColor(int)
.addSpacing(int, int, From)
.You can also specify the design spec in a raw JSON resource like:
{
"baselineGridVisible": true,
"baselineGridCellSize": 8,
"keylines": [
{ "offset": 16,
"from": "LEFT" },
{ "offset": 72,
"from": "LEFT" },
{ "offset": 16,
"from": "RIGHT" }
],
"spacings": [
{ "offset": 0,
"size": 16,
"from": "LEFT" },
{ "offset": 56,
"size": 16,
"from": "LEFT" },
{ "offset": 0,
"size": 16,
"from": "RIGHT" }
]
}
Because DesignSpec
is a Drawable
, you can simply add it to a
ViewOverlay
if you're running your app on API level >= 18:
DesignSpec designSpec = DesignSpec.fromResource(someView, R.raw.some_spec);
someView.getOverlay().add(designSpec);
Download the latest JAR or grab via Gradle:
compile 'org.lucasr.dspec:dspec:0.1.1'
or Maven:
<dependency>
<groupId>org.lucasr.dspec</groupId>
<artifactId>dspec</artifactId>
<version>0.1.1</version>
</dependency>
Copyright 2014 Lucas Rocha
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.