mirror of
https://github.com/status-im/react-native.git
synced 2025-01-14 03:26:07 +00:00
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:
parent
78c6e416ae
commit
cd89016ee7
@ -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,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -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: {
|
||||||
|
@ -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: {
|
||||||
|
@ -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: {
|
||||||
|
@ -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: {
|
||||||
|
@ -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: {
|
||||||
|
@ -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,
|
||||||
},
|
},
|
||||||
|
@ -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',
|
||||||
},
|
},
|
||||||
|
@ -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,
|
||||||
},
|
},
|
||||||
|
@ -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: {
|
||||||
|
@ -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: {
|
||||||
|
@ -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;
|
|
||||||
|
@ -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() {}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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');
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user