From edc3aa51633017a9d9b45d75e744af223206a34e Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sat, 1 Sep 2018 17:49:45 +0100 Subject: [PATCH 1/5] experimenting with react native fastimage module --- app/package-lock.json | 5 +++ app/package.json | 1 + app/src/component/fileItemMedia/view.js | 43 ++++++++++++++++--- app/src/styles/discover.js | 2 +- .../lbry/build/templates/build.tmpl.gradle | 9 +++- .../lbry/build/templates/settings.tmpl.gradle | 6 ++- .../java/io/lbry/browser/MainActivity.java | 2 + 7 files changed, 57 insertions(+), 11 deletions(-) diff --git a/app/package-lock.json b/app/package-lock.json index 071ff511..e45329a1 100644 --- a/app/package-lock.json +++ b/app/package-lock.json @@ -5188,6 +5188,11 @@ "react-native-drawer-layout": "1.3.2" } }, + "react-native-fast-image": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/react-native-fast-image/-/react-native-fast-image-5.0.3.tgz", + "integrity": "sha512-70XlQPt8b7yQSMwUEEIN5jTx7KOx1EBD2XhIRIEHChfNv5Gwn8dh28RSo/Dq9qezf4CWJXO3CAb4lq+Hu9d0vw==" + }, "react-native-fetch-blob": { "version": "0.10.8", "resolved": "https://registry.npmjs.org/react-native-fetch-blob/-/react-native-fetch-blob-0.10.8.tgz", diff --git a/app/package.json b/app/package.json index 14315b12..f70e51c8 100644 --- a/app/package.json +++ b/app/package.json @@ -12,6 +12,7 @@ "moment": "^2.22.1", "react": "16.2.0", "react-native": "0.55.3", + "react-native-fast-image": "^5.0.3", "react-native-fetch-blob": "^0.10.8", "react-native-image-zoom-viewer": "^2.2.5", "react-native-vector-icons": "^5.0.0", diff --git a/app/src/component/fileItemMedia/view.js b/app/src/component/fileItemMedia/view.js index 9541916a..e4d792cd 100644 --- a/app/src/component/fileItemMedia/view.js +++ b/app/src/component/fileItemMedia/view.js @@ -1,6 +1,7 @@ import React from 'react'; import { ActivityIndicator, Image, Text, View } from 'react-native'; import Colors from '../../styles/colors'; +import FastImage from 'react-native-fast-image' import fileItemMediaStyle from '../../styles/fileItemMedia'; class FileItemMedia extends React.PureComponent { @@ -18,6 +19,10 @@ class FileItemMedia extends React.PureComponent { fileItemMediaStyle.autothumbOrange, ]; + state: { + imageLoadFailed: false + }; + componentWillMount() { this.setState({ autoThumbStyle: @@ -27,21 +32,47 @@ class FileItemMedia extends React.PureComponent { }); } + getFastImageResizeMode(resizeMode) { + switch (resizeMode) { + case "contain": + return FastImage.resizeMode.contain; + case "stretch": + console.log('using stretch resize mode...'); + return FastImage.resizeMode.stretch; + case "center": + return FastImage.resizeMode.center; + default: + return FastImage.resizeMode.cover; + } + } + render() { let style = this.props.style; const { blurRadius, isResolvingUri, thumbnail, title, resizeMode } = this.props; const atStyle = this.state.autoThumbStyle; - - if (thumbnail && ((typeof thumbnail) === 'string')) { + if (thumbnail && ((typeof thumbnail) === 'string') && !this.state.imageLoadFailed) { if (style == null) { style = fileItemMediaStyle.thumbnail; } + if (blurRadius > 0) { + // No blur radius support in FastImage yet + return ( + ); + } + return ( - + this.setState({ imageLoadFailed: true })} + resizeMode={this.getFastImageResizeMode(resizeMode)} + style={style} + /> ); } diff --git a/app/src/styles/discover.js b/app/src/styles/discover.js index a5f71bfc..883d91d6 100644 --- a/app/src/styles/discover.js +++ b/app/src/styles/discover.js @@ -7,7 +7,7 @@ const screenHeight = screenDimension.height; // calculate thumbnail width and height based on device's aspect ratio const horizontalMargin = 48; // left and right margins (24 + 24) const verticalMargin = (screenWidth / screenHeight) * horizontalMargin; -const mediaWidth = screenWidth - horizontalMargin; +const mediaWidth = screenWidth - 64; const mediaHeight = (screenWidth / (screenHeight - verticalMargin)) * mediaWidth; const discoverStyle = StyleSheet.create({ diff --git a/p4a/pythonforandroid/bootstraps/lbry/build/templates/build.tmpl.gradle b/p4a/pythonforandroid/bootstraps/lbry/build/templates/build.tmpl.gradle index acb74d2a..5d8b782c 100644 --- a/p4a/pythonforandroid/bootstraps/lbry/build/templates/build.tmpl.gradle +++ b/p4a/pythonforandroid/bootstraps/lbry/build/templates/build.tmpl.gradle @@ -40,6 +40,10 @@ android { } } + dexOptions { + jumboMode true + } + {% if args.sign -%} signingConfigs { release { @@ -80,9 +84,10 @@ subprojects { } dependencies { - compile project(':react-native-video') + compile project(':react-native-fast-image') compile project(':react-native-fetch-blob') - {%- for aar in aars %} + compile project(':react-native-video') + {%- for aar in aars %} compile(name: '{{ aar }}', ext: 'aar') {%- endfor -%} {%- if args.depends -%} diff --git a/p4a/pythonforandroid/bootstraps/lbry/build/templates/settings.tmpl.gradle b/p4a/pythonforandroid/bootstraps/lbry/build/templates/settings.tmpl.gradle index 33372a15..aeb014f7 100644 --- a/p4a/pythonforandroid/bootstraps/lbry/build/templates/settings.tmpl.gradle +++ b/p4a/pythonforandroid/bootstraps/lbry/build/templates/settings.tmpl.gradle @@ -1,5 +1,7 @@ rootProject.name = 'browser' -include ':react-native-video' -project(':react-native-video').projectDir = new File(rootProject.projectDir, './react/node_modules/react-native-video/android-exoplayer') +include ':react-native-fast-image' +project(':react-native-fast-image').projectDir = new File(rootProject.projectDir, './react/node_modules/react-native-fast-image/android') include ':react-native-fetch-blob' project(':react-native-fetch-blob').projectDir = new File(rootProject.projectDir, './react/node_modules/react-native-fetch-blob/android') +include ':react-native-video' +project(':react-native-video').projectDir = new File(rootProject.projectDir, './react/node_modules/react-native-video/android-exoplayer') diff --git a/src/main/java/io/lbry/browser/MainActivity.java b/src/main/java/io/lbry/browser/MainActivity.java index feaada3e..bc04e8c5 100644 --- a/src/main/java/io/lbry/browser/MainActivity.java +++ b/src/main/java/io/lbry/browser/MainActivity.java @@ -20,6 +20,7 @@ import android.telephony.TelephonyManager; import android.widget.Toast; import com.brentvatne.react.ReactVideoPackage; +import com.dylanvann.fastimage.FastImageViewPackage; import com.facebook.react.common.LifecycleState; import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler; import com.facebook.react.ReactRootView; @@ -103,6 +104,7 @@ public class MainActivity extends Activity implements DefaultHardwareBackBtnHand .setBundleAssetName("index.android.bundle") .setJSMainModulePath("index") .addPackage(new MainReactPackage()) + .addPackage(new FastImageViewPackage()) .addPackage(new ReactVideoPackage()) .addPackage(new RNFetchBlobPackage()) .addPackage(new LbryReactPackage()) -- 2.45.3 From 7872567f89f94d52cf2eeb5607e9d908735fa2e8 Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sat, 1 Sep 2018 19:56:40 +0100 Subject: [PATCH 2/5] thumbnail aspect ratio sizing tweaks --- app/package-lock.json | 11 ++++++++++- app/src/styles/discover.js | 10 ++++++---- app/src/styles/fileList.js | 15 ++++++++------- 3 files changed, 24 insertions(+), 12 deletions(-) diff --git a/app/package-lock.json b/app/package-lock.json index e45329a1..aa9b0b43 100644 --- a/app/package-lock.json +++ b/app/package-lock.json @@ -3969,8 +3969,17 @@ "version": "github:lbryio/lbryinc#678c5098e2099dd1560b2fefa2795f38ca3ce07b", "from": "github:lbryio/lbryinc", "requires": { - "lbry-redux": "github:lbryio/lbry-redux#31f7afa8a37f5741dac01fc1ecdf153f3bed95dc", "reselect": "^3.0.0" + }, + "dependencies": { + "lbry-redux": { + "version": "github:lbryio/lbry-redux#31f7afa8a37f5741dac01fc1ecdf153f3bed95dc", + "from": "github:lbryio/lbry-redux#31f7afa8a37f5741dac01fc1ecdf153f3bed95dc", + "requires": { + "proxy-polyfill": "0.1.6", + "reselect": "^3.0.0" + } + } } }, "lcid": { diff --git a/app/src/styles/discover.js b/app/src/styles/discover.js index 883d91d6..e70f73fb 100644 --- a/app/src/styles/discover.js +++ b/app/src/styles/discover.js @@ -1,14 +1,16 @@ -import { Dimensions, StyleSheet } from 'react-native'; +import { Dimensions, PixelRatio, StyleSheet } from 'react-native'; import Colors from './colors'; const screenDimension = Dimensions.get('window'); const screenWidth = screenDimension.width; const screenHeight = screenDimension.height; +const screenWidthPixels = PixelRatio.getPixelSizeForLayoutSize(screenWidth); +const screenHeightPixels = PixelRatio.getPixelSizeForLayoutSize(screenHeight); // calculate thumbnail width and height based on device's aspect ratio const horizontalMargin = 48; // left and right margins (24 + 24) -const verticalMargin = (screenWidth / screenHeight) * horizontalMargin; -const mediaWidth = screenWidth - 64; -const mediaHeight = (screenWidth / (screenHeight - verticalMargin)) * mediaWidth; +const verticalMargin = (screenWidthPixels > 720 && screenHeightPixels > 1080) ? 0 : ((screenWidthPixels <= 720) ? 20 : 16); +const mediaWidth = screenWidth - horizontalMargin; +const mediaHeight = ((screenWidth / screenHeight) * ((screenWidthPixels <= 720) ? screenWidth : mediaWidth)) - verticalMargin; const discoverStyle = StyleSheet.create({ container: { diff --git a/app/src/styles/fileList.js b/app/src/styles/fileList.js index dfaec77a..84dab8c2 100644 --- a/app/src/styles/fileList.js +++ b/app/src/styles/fileList.js @@ -1,10 +1,11 @@ -import { Dimensions, StyleSheet } from 'react-native'; +import { Dimensions, PixelRatio, StyleSheet } from 'react-native'; import Colors from './colors'; const screenDimension = Dimensions.get('window'); const screenWidth = screenDimension.width; const screenHeight = screenDimension.height; -const thumbnailHeight = 100; +const screenWidthPixels = PixelRatio.getPixelSizeForLayoutSize(screenWidth); +const thumbnailHeight = (screenWidthPixels <= 720) ? 72 : 96; const thumbnailWidth = (screenHeight / screenWidth) * thumbnailHeight; const fileListStyle = StyleSheet.create({ @@ -20,21 +21,21 @@ const fileListStyle = StyleSheet.create({ thumbnail: { width: thumbnailWidth, height: thumbnailHeight, - marginRight: 16, + marginRight: (screenWidthPixels <= 720) ? 10 : 12, justifyContent: 'center' }, title: { fontFamily: 'Metropolis-SemiBold', - fontSize: 16 + fontSize: (screenWidthPixels <= 720) ? 14 : 16 }, uri: { fontFamily: 'Metropolis-SemiBold', - fontSize: 14, + fontSize: (screenWidthPixels <= 720) ? 12 : 14, marginBottom: 8 }, publisher: { fontFamily: 'Metropolis-SemiBold', - fontSize: 14, + fontSize: (screenWidthPixels <= 720) ? 12 : 14, marginTop: 3, color: Colors.LbryGreen }, @@ -46,7 +47,7 @@ const fileListStyle = StyleSheet.create({ }, downloadStorage: { fontFamily: 'Metropolis-Regular', - fontSize: 14, + fontSize: (screenWidthPixels <= 720) ? 12 : 14, color: Colors.ChannelGrey }, progress: { -- 2.45.3 From 6050a4366713ae91a78f27099b0332de624d1f46 Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sat, 1 Sep 2018 21:32:01 +0100 Subject: [PATCH 3/5] more thumbnail sizing tweaks --- app/src/styles/discover.js | 3 ++- app/src/styles/fileList.js | 16 +++++++++------- app/src/styles/search.js | 2 +- 3 files changed, 12 insertions(+), 9 deletions(-) diff --git a/app/src/styles/discover.js b/app/src/styles/discover.js index e70f73fb..1b5a0162 100644 --- a/app/src/styles/discover.js +++ b/app/src/styles/discover.js @@ -6,9 +6,10 @@ const screenWidth = screenDimension.width; const screenHeight = screenDimension.height; const screenWidthPixels = PixelRatio.getPixelSizeForLayoutSize(screenWidth); const screenHeightPixels = PixelRatio.getPixelSizeForLayoutSize(screenHeight); +console.log('screenHeightPixels=' + screenHeightPixels); // calculate thumbnail width and height based on device's aspect ratio const horizontalMargin = 48; // left and right margins (24 + 24) -const verticalMargin = (screenWidthPixels > 720 && screenHeightPixels > 1080) ? 0 : ((screenWidthPixels <= 720) ? 20 : 16); +const verticalMargin = (screenWidthPixels > 720 && screenHeightPixels > 1920) ? 0 : ((screenWidthPixels <= 720) ? 20 : 16); const mediaWidth = screenWidth - horizontalMargin; const mediaHeight = ((screenWidth / screenHeight) * ((screenWidthPixels <= 720) ? screenWidth : mediaWidth)) - verticalMargin; diff --git a/app/src/styles/fileList.js b/app/src/styles/fileList.js index 84dab8c2..bc684a03 100644 --- a/app/src/styles/fileList.js +++ b/app/src/styles/fileList.js @@ -5,15 +5,17 @@ const screenDimension = Dimensions.get('window'); const screenWidth = screenDimension.width; const screenHeight = screenDimension.height; const screenWidthPixels = PixelRatio.getPixelSizeForLayoutSize(screenWidth); -const thumbnailHeight = (screenWidthPixels <= 720) ? 72 : 96; -const thumbnailWidth = (screenHeight / screenWidth) * thumbnailHeight; +const screenHeightPixels = PixelRatio.getPixelSizeForLayoutSize(screenHeight); +const verticalAdjust = (screenHeightPixels > 1280 && screenHeightPixels <= 1920) ? 6 : 0; +const thumbnailWidth = (screenWidthPixels <= 720) ? 144 : 156; +const thumbnailHeight = ((screenWidth / screenHeight) * thumbnailWidth) - verticalAdjust; const fileListStyle = StyleSheet.create({ item: { flex: 1, flexDirection: 'row', justifyContent: 'space-between', - marginTop: 16 + marginTop: 8 }, detailsContainer: { flex: 1 @@ -26,7 +28,7 @@ const fileListStyle = StyleSheet.create({ }, title: { fontFamily: 'Metropolis-SemiBold', - fontSize: (screenWidthPixels <= 720) ? 14 : 16 + fontSize: (screenWidthPixels <= 720) ? 12 : 16 }, uri: { fontFamily: 'Metropolis-SemiBold', @@ -36,14 +38,14 @@ const fileListStyle = StyleSheet.create({ publisher: { fontFamily: 'Metropolis-SemiBold', fontSize: (screenWidthPixels <= 720) ? 12 : 14, - marginTop: 3, + marginTop: (screenWidthPixels <= 720) ? 1 : 3, color: Colors.LbryGreen }, loading: { position: 'absolute' }, downloadInfo: { - marginTop: 8 + marginTop: (screenWidthPixels <= 720) ? 4 : 8 }, downloadStorage: { fontFamily: 'Metropolis-Regular', @@ -51,7 +53,7 @@ const fileListStyle = StyleSheet.create({ color: Colors.ChannelGrey }, progress: { - marginTop: 4, + marginTop: (screenWidthPixels <= 720) ? 2 : 4, height: 3, flex: 1, flexDirection: 'row' diff --git a/app/src/styles/search.js b/app/src/styles/search.js index 7d6c9711..ac3ca9d2 100644 --- a/app/src/styles/search.js +++ b/app/src/styles/search.js @@ -21,7 +21,7 @@ const searchStyle = StyleSheet.create({ flex: 1, flexDirection: 'row', justifyContent: 'space-between', - marginTop: 16 + marginTop: 8 }, searchInput: { width: '100%', -- 2.45.3 From 608339c788c00ec8019527e76da1b5f2e19015be Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sat, 1 Sep 2018 21:33:51 +0100 Subject: [PATCH 4/5] show approximate values for formatted bytes --- app/src/component/fileListItem/view.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/app/src/component/fileListItem/view.js b/app/src/component/fileListItem/view.js index 2d3c4ac4..a38c31a2 100644 --- a/app/src/component/fileListItem/view.js +++ b/app/src/component/fileListItem/view.js @@ -27,16 +27,16 @@ class FileListItem extends React.PureComponent { formatBytes = (bytes) => { if (bytes < 1048576) { // < 1MB - const value = (bytes / 1024.0).toFixed(2); + const value = (bytes / 1024.0).toFixed(0); return `${value} KB`; } if (bytes < 1073741824) { // < 1GB - const value = (bytes / (1024.0 * 1024.0)).toFixed(2); + const value = (bytes / (1024.0 * 1024.0)).toFixed(0); return `${value} MB`; } - const value = (bytes / (1024.0 * 1024.0 * 1024.0)).toFixed(2); + const value = (bytes / (1024.0 * 1024.0 * 1024.0)).toFixed(0); return `${value} GB`; } -- 2.45.3 From 91000a972de61bac5525f26297ffc4a5a683f7b8 Mon Sep 17 00:00:00 2001 From: Akinwale Ariwodola Date: Sat, 1 Sep 2018 21:43:19 +0100 Subject: [PATCH 5/5] truncate titles over 80 characters in the file item list component --- app/src/component/fileListItem/view.js | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/app/src/component/fileListItem/view.js b/app/src/component/fileListItem/view.js index a38c31a2..8191652d 100644 --- a/app/src/component/fileListItem/view.js +++ b/app/src/component/fileListItem/view.js @@ -40,6 +40,14 @@ class FileListItem extends React.PureComponent { return `${value} GB`; } + formatTitle = (title) => { + if (!title) { + return title; + } + + return (title.length > 80) ? title.substring(0, 77).trim() + '...' : title; + } + getDownloadProgress = (fileInfo) => { return Math.ceil((fileInfo.written_bytes / fileInfo.total_bytes) * 100); } @@ -85,7 +93,7 @@ class FileListItem extends React.PureComponent { )} - {!isResolving && {title || name}} + {!isResolving && {this.formatTitle(title) || this.formatTitle(name)}} {!isResolving && channel && { const channelUri = normalizeURI(channel); -- 2.45.3