util.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. import $site from "./site";
  2. const ksort = obj => {
  3. let keys = Object.keys(obj).sort()
  4. , sortedObj = {};
  5. for (let i in keys) {
  6. sortedObj[keys[i]] = obj[keys[i]];
  7. }
  8. return sortedObj;
  9. }
  10. const checkNullObj = (obj) => {
  11. if (Object.keys(obj).length === 0) {
  12. return false
  13. }
  14. return true
  15. }
  16. const checkArrayNotNullNumber = (array,notNullNumber = 2) => {
  17. let num = 0
  18. for (const item in array) {
  19. if(array[item]) num++;
  20. }
  21. return num >= notNullNumber;
  22. }
  23. // 正切
  24. const tan = angle => {
  25. return Math.tan(angle * Math.PI / 180)
  26. }
  27. // 余切
  28. const cot = angle => {
  29. return 1 / tan(angle)
  30. }
  31. // 余弦
  32. const cos = angle => {
  33. return Math.cos(angle * Math.PI / 180)
  34. }
  35. // 余割
  36. const csc = angle => {
  37. return 1 / sin(angle)
  38. }
  39. // 正弦
  40. const sin = angle => {
  41. return Math.sin(angle * Math.PI / 180)
  42. }
  43. // 正割
  44. const sec = angle => {
  45. return 1 / cos(angle)
  46. }
  47. // 反正弦
  48. const asin = value => {
  49. return Math.asin(value) * 180 / Math.PI;
  50. }
  51. // 反余弦
  52. const acos = value => {
  53. return Math.acos(value) * 180 / Math.PI;
  54. }
  55. // 反正切
  56. const atan = value => {
  57. return Math.atan(value) * 180 / Math.PI;
  58. }
  59. const checkTriangle = (a,b,c) => {
  60. a = parseInt(a);
  61. b= parseInt(b);
  62. c = parseInt(c);
  63. return a + b > c && a + c > b && b + c > a;
  64. }
  65. const round = (number,percent) => {
  66. if(!number) return number
  67. let flag = number < 0 ? '-' : '';
  68. let arr = number.toString().split(".");
  69. if(arr.length > 1 && arr[1].length === 2) return number
  70. let i = Number('1'.padEnd(percent+1,'0'))
  71. number = Math.floor(Math.abs(Number(number)) * i) / i
  72. if(arr.length > 1 ){
  73. let str = arr[1]
  74. if(str.length > 2 && str[2] >= 5){
  75. number = Math.ceil(number * i)
  76. number += 1;
  77. number = number / i;
  78. }
  79. }
  80. if(number.toString().indexOf(".") === -1) number += ".0"
  81. arr = number.toString().split(".");
  82. arr[1] = arr[1].toString().padEnd(2,'0')
  83. number = arr.join(".")
  84. return flag+number;
  85. }
  86. const objectToUrlParams = function (obj, urlencode) {
  87. let str = "";
  88. for (let key in obj) {
  89. str += "&" + key + "=" + (urlencode ? encodeURIComponent(obj[key]) : obj[key]);
  90. }
  91. return str.substr(1);
  92. }
  93. const shareMessage = user => {
  94. let args = {
  95. path: '/pages/index/index',
  96. params: {
  97. user_id : user.id,
  98. },
  99. title: '桥架计算和公示表永久使用',
  100. desc: '做桥架不求人,让你秒变大师!',
  101. imageUrl: $site.root+"assets/images/formula/formula-cover.png"
  102. };
  103. return args ;
  104. }
  105. /**
  106. * WXSceneSession 分享到聊天界面
  107. * WXSenceTimeline 分享到朋友圈
  108. * WXSceneFavorite 分享到微信收藏
  109. * @param user
  110. * @param scene
  111. */
  112. const share = (user,scene = "WXSenceTimeline") => {
  113. uni.share({
  114. provider: "weixin",
  115. scene: scene,
  116. type: 5, // 小程序
  117. miniProgram: {
  118. id: 'gh_cdaf361f6966',
  119. path:'/pages/index/index?user_id='+user.id,
  120. },
  121. title: '桥架计算和公示表永久使用',
  122. summary: "做桥架不求人,让你秒变大师!",
  123. imageUrl: $site.root+"assets/images/formula/formula-cover.png",
  124. success: function (res) {
  125. console.log("success:" + JSON.stringify(res));
  126. },
  127. fail: function (err) {
  128. console.error("fail:" + JSON.stringify(err));
  129. }
  130. });
  131. }
  132. const login = () => {
  133. let page = getCurrentPages()[0]
  134. let route = page.route;
  135. let arr = [];
  136. for (const key in page.options) {
  137. arr.push(`${key}=${page.options[key]}`)
  138. }
  139. uni.reLaunch({
  140. url: `/pages/login/login?redirect=${route}&${arr.join("&")}`,
  141. });
  142. }
  143. const saveImage = url => {
  144. return new Promise((resolve, reject) => {
  145. uni.downloadFile({
  146. url: url,
  147. success: (res) => {
  148. if (res.statusCode === 200) {
  149. console.log('下载成功');
  150. uni.authorize({
  151. scope: 'scope.writePhotosAlbum',
  152. success() {
  153. uni.saveImageToPhotosAlbum({
  154. filePath: res.tempFilePath,
  155. success: function(red) {
  156. uni.$u.toast(`保存成功`)
  157. //uni.$u.toast(`保存路径:${red.savedFilePath}`)
  158. resolve()
  159. },
  160. fail: function() {
  161. uni.$u.toast(`保存失败`)
  162. reject()
  163. }
  164. });
  165. },
  166. fail: err => {
  167. uni.$u.toast(`授权失败`+JSON.stringify(err))
  168. reject()
  169. }
  170. })
  171. }else{
  172. uni.$u.toast(`保存失败`)
  173. reject()
  174. }
  175. },
  176. fail: err => {
  177. uni.$u.toast(`保存失败`+JSON.stringify(err))
  178. reject()
  179. }
  180. });
  181. })
  182. }
  183. const copyText = text => {
  184. uni.setClipboardData({
  185. data: text,
  186. success: function () {
  187. uni.hideLoading();
  188. uni.$u.toast(`复制成功`)
  189. }
  190. });
  191. }
  192. export {
  193. ksort,
  194. checkNullObj,
  195. checkArrayNotNullNumber,
  196. tan,
  197. cot,
  198. cos,
  199. csc,
  200. sin,
  201. sec,
  202. asin,
  203. acos,
  204. atan,
  205. checkTriangle,
  206. round,
  207. objectToUrlParams,
  208. shareMessage,
  209. share,
  210. login,
  211. saveImage,
  212. copyText
  213. }