PixelRatio.pixel()

Summary:
This implements #5073. It adds a static method `PixelRatio.pixel()` which returns the smallest drawable line width, primarily for use in styles.

It also updates the example apps to use the new function.
Closes https://github.com/facebook/react-native/pull/5076

Reviewed By: svcscm

Differential Revision: D2799849

Pulled By: nicklockwood

fb-gh-sync-id: b83a77790601fe882affbf65531114e7c5cf4bdf
This commit is contained in:
Kyle Corbitt 2016-01-15 05:14:27 -08:00 committed by facebook-github-bot-5
parent 78c6e416ae
commit cd89016ee7
15 changed files with 60 additions and 49 deletions

View File

@ -18,7 +18,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
Image, Image,
PixelRatio,
Platform, Platform,
StyleSheet, StyleSheet,
Text, Text,
@ -99,8 +98,7 @@ var styles = StyleSheet.create({
}, },
cellBorder: { cellBorder: {
backgroundColor: 'rgba(0, 0, 0, 0.1)', backgroundColor: 'rgba(0, 0, 0, 0.1)',
// Trick to get the thinest line the device can display height: StyleSheet.hairlineWidth,
height: 1 / PixelRatio.get(),
marginLeft: 4, marginLeft: 4,
}, },
}); });

View File

@ -18,7 +18,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
Image, Image,
PixelRatio,
ScrollView, ScrollView,
StyleSheet, StyleSheet,
Text, Text,
@ -152,7 +151,7 @@ var styles = StyleSheet.create({
}, },
separator: { separator: {
backgroundColor: 'rgba(0, 0, 0, 0.1)', backgroundColor: 'rgba(0, 0, 0, 0.1)',
height: 1 / PixelRatio.get(), height: StyleSheet.hairlineWidth,
marginVertical: 10, marginVertical: 10,
}, },
castTitle: { castTitle: {

View File

@ -15,7 +15,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
PixelRatio,
Navigator, Navigator,
StyleSheet, StyleSheet,
ScrollView, ScrollView,
@ -131,7 +130,7 @@ var styles = StyleSheet.create({
button: { button: {
backgroundColor: 'white', backgroundColor: 'white',
padding: 15, padding: 15,
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: '#CDCDCD', borderBottomColor: '#CDCDCD',
}, },
buttonText: { buttonText: {

View File

@ -16,7 +16,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
Navigator, Navigator,
PixelRatio,
StyleSheet, StyleSheet,
ScrollView, ScrollView,
TabBarIOS, TabBarIOS,
@ -185,7 +184,7 @@ var styles = StyleSheet.create({
button: { button: {
backgroundColor: 'white', backgroundColor: 'white',
padding: 15, padding: 15,
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: '#CDCDCD', borderBottomColor: '#CDCDCD',
}, },
buttonText: { buttonText: {

View File

@ -16,7 +16,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
PixelRatio,
Navigator, Navigator,
ScrollView, ScrollView,
StyleSheet, StyleSheet,
@ -164,7 +163,7 @@ var styles = StyleSheet.create({
button: { button: {
backgroundColor: 'white', backgroundColor: 'white',
padding: 15, padding: 15,
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: '#CDCDCD', borderBottomColor: '#CDCDCD',
}, },
buttonText: { buttonText: {

View File

@ -16,7 +16,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
Navigator, Navigator,
PixelRatio,
ScrollView, ScrollView,
StyleSheet, StyleSheet,
Text, Text,
@ -190,7 +189,7 @@ var styles = StyleSheet.create({
button: { button: {
backgroundColor: 'white', backgroundColor: 'white',
padding: 15, padding: 15,
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: '#CDCDCD', borderBottomColor: '#CDCDCD',
}, },
buttonText: { buttonText: {

View File

@ -20,7 +20,6 @@ var ViewExample = require('./ViewExample');
var createExamplePage = require('./createExamplePage'); var createExamplePage = require('./createExamplePage');
var { var {
AlertIOS, AlertIOS,
PixelRatio,
ScrollView, ScrollView,
StyleSheet, StyleSheet,
Text, Text,
@ -227,7 +226,7 @@ var styles = StyleSheet.create({
}, },
line: { line: {
backgroundColor: '#bbbbbb', backgroundColor: '#bbbbbb',
height: 1 / PixelRatio.get(), height: StyleSheet.hairlineWidth,
}, },
row: { row: {
backgroundColor: 'white', backgroundColor: 'white',
@ -236,7 +235,7 @@ var styles = StyleSheet.create({
paddingVertical: 15, paddingVertical: 15,
}, },
separator: { separator: {
height: 1 / PixelRatio.get(), height: StyleSheet.hairlineWidth,
backgroundColor: '#bbbbbb', backgroundColor: '#bbbbbb',
marginLeft: 15, marginLeft: 15,
}, },

View File

@ -229,7 +229,7 @@ var styles = StyleSheet.create({
logBox: { logBox: {
padding: 20, padding: 20,
margin: 10, margin: 10,
borderWidth: 1 / PixelRatio.get(), borderWidth: StyleSheet.hairlineWidth,
borderColor: '#f0f0f0', borderColor: '#f0f0f0',
backgroundColor: '#f9f9f9', backgroundColor: '#f9f9f9',
}, },
@ -237,7 +237,7 @@ var styles = StyleSheet.create({
padding: 10, padding: 10,
margin: 10, margin: 10,
height: 120, height: 120,
borderWidth: 1 / PixelRatio.get(), borderWidth: StyleSheet.hairlineWidth,
borderColor: '#f0f0f0', borderColor: '#f0f0f0',
backgroundColor: '#f9f9f9', backgroundColor: '#f9f9f9',
}, },

View File

@ -18,7 +18,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
ListView, ListView,
PixelRatio,
StyleSheet, StyleSheet,
Text, Text,
TextInput, TextInput,
@ -159,7 +158,7 @@ var styles = StyleSheet.create({
paddingVertical: 8, paddingVertical: 8,
}, },
separator: { separator: {
height: 1 / PixelRatio.get(), height: StyleSheet.hairlineWidth,
backgroundColor: '#bbbbbb', backgroundColor: '#bbbbbb',
marginLeft: 15, marginLeft: 15,
}, },

View File

@ -17,7 +17,6 @@
var React = require('react-native'); var React = require('react-native');
var { var {
PixelRatio,
ProgressBarAndroid, ProgressBarAndroid,
StyleSheet, StyleSheet,
Text, Text,
@ -312,7 +311,7 @@ var styles = StyleSheet.create({
flexDirection: 'row', flexDirection: 'row',
paddingVertical: 8, paddingVertical: 8,
alignItems: 'center', alignItems: 'center',
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: 'grey', borderBottomColor: 'grey',
}, },
textButton: { textButton: {

View File

@ -21,7 +21,6 @@ var {
CameraRoll, CameraRoll,
Image, Image,
LinkingIOS, LinkingIOS,
PixelRatio,
ProgressViewIOS, ProgressViewIOS,
StyleSheet, StyleSheet,
Text, Text,
@ -343,7 +342,7 @@ var styles = StyleSheet.create({
flexDirection: 'row', flexDirection: 'row',
paddingVertical: 8, paddingVertical: 8,
alignItems: 'center', alignItems: 'center',
borderBottomWidth: 1 / PixelRatio.get(), borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: 'grey', borderBottomColor: 'grey',
}, },
photoLabel: { photoLabel: {

View File

@ -11,9 +11,16 @@
*/ */
'use strict'; 'use strict';
var PixelRatio = require('PixelRatio');
var StyleSheetRegistry = require('StyleSheetRegistry'); var StyleSheetRegistry = require('StyleSheetRegistry');
var StyleSheetValidation = require('StyleSheetValidation'); var StyleSheetValidation = require('StyleSheetValidation');
var flattenStyle = require('flattenStyle');
var flatten = require('flattenStyle');
var hairlineWidth = PixelRatio.roundToNearestPixel(0.4);
if (hairlineWidth === 0) {
hairlineWidth = 1 / PixelRatio.get();
}
/** /**
* A StyleSheet is an abstraction similar to CSS StyleSheets * A StyleSheet is an abstraction similar to CSS StyleSheets
@ -59,10 +66,32 @@ var flattenStyle = require('flattenStyle');
* - It also allows to send the style only once through the bridge. All * - It also allows to send the style only once through the bridge. All
* subsequent uses are going to refer an id (not implemented yet). * subsequent uses are going to refer an id (not implemented yet).
*/ */
class StyleSheet { module.exports = {
static flatten: typeof flattenStyle; /**
* This is defined as the width of a thin line on the platform. It can be
* used as the thickness of a border or division between two elements.
* Example:
* ```
* {
* borderBottomColor: '#bbb',
* borderBottomWidth: StyleSheet.hairlineWidth
* }
* ```
*
* This constant will always be a round number of pixels (so a line defined
* by it look crisp) and will try to match the standard width of a thin line
* on the underlying platform. However, you should not rely on it being a
* constant size, because on different platforms and screen densities its
* value may be calculated differently.
*/
hairlineWidth,
static create(obj: {[key: string]: any}): {[key: string]: number} { flatten,
/**
* Creates a StyleSheet style reference from the given object.
*/
create(obj: {[key: string]: any}): {[key: string]: number} {
var result = {}; var result = {};
for (var key in obj) { for (var key in obj) {
StyleSheetValidation.validateStyle(key, obj); StyleSheetValidation.validateStyle(key, obj);
@ -70,9 +99,4 @@ class StyleSheet {
} }
return result; return result;
} }
} };
/* TODO(brentvatne) docs are needed for this */
StyleSheet.flatten = flattenStyle;
module.exports = StyleSheet;

View File

@ -16,20 +16,6 @@ var Dimensions = require('Dimensions');
/** /**
* PixelRatio class gives access to the device pixel density. * PixelRatio class gives access to the device pixel density.
* *
* There are a few use cases for using PixelRatio:
*
* ### Displaying a line that's as thin as the device permits
*
* A width of 1 is actually pretty thick on devices with high pixel density
* (such as iPhone 4+ and many Android devices), we can make one that's
* thinner using a width of `1 / PixelRatio.get()`.
* It's a technique that works on all the devices independent of their
* pixel density.
*
* ```
* style={{ borderWidth: 1 / PixelRatio.get() }}
* ```
*
* ### Fetching a correctly sized image * ### Fetching a correctly sized image
* *
* You should get a higher resolution image if you are on a high pixel density * You should get a higher resolution image if you are on a high pixel density
@ -91,6 +77,17 @@ class PixelRatio {
return Math.round(layoutSize * PixelRatio.get()); return Math.round(layoutSize * PixelRatio.get());
} }
/**
* Rounds a layout size (dp) to the nearest layout size that corresponds to
* an integer number of pixels. For example, on a device with a PixelRatio
* of 3, `PixelRatio.roundToNearestPixel(8.4) = 8.33`, which corresponds to
* exactly (8.33 * 3) = 25 pixels.
*/
static roundToNearestPixel(layoutSize: number): number {
var ratio = PixelRatio.get();
return Math.round(layoutSize * ratio) / ratio;
}
// No-op for iOS, but used on the web. Should not be documented. // No-op for iOS, but used on the web. Should not be documented.
static startDetecting() {} static startDetecting() {}
} }

View File

@ -82,7 +82,7 @@
self.bounds = bounds; self.bounds = bounds;
} }
- (void)reactSetInheritedBackgroundColor:(UIColor *)inheritedBackgroundColor - (void)reactSetInheritedBackgroundColor:(__unused UIColor *)inheritedBackgroundColor
{ {
// Does nothing by default // Does nothing by default
} }

View File

@ -10,6 +10,7 @@
jest.dontMock('../') jest.dontMock('../')
.dontMock('underscore') .dontMock('underscore')
.dontMock('PixelRatio')
.dontMock('../../DependencyResolver/lib/extractRequires') .dontMock('../../DependencyResolver/lib/extractRequires')
.dontMock('../../DependencyResolver/lib/replacePatterns'); .dontMock('../../DependencyResolver/lib/replacePatterns');