Vue 实战商业级读书Web APP 全面提升技能

Vue 实战商业级读书Web APP 全面提升技能,第1张

概述download:Vue实战商业级读书WebAPP全面提升技能运用Vue最新技术开发一个可商用、各项功能完备、媲美原生App的Web阅读应用。在开发中,将各种知识点穿插应用,让你真实感受到一个明星产品开发的全过程,项目对阅读器有着较为深入的研究,对各种复杂功能有从原理到实现的详细教学 download:Vue 实战商业级读书Web APP 全面提升技能

运用Vue最新技术开发一个可商用、各项功能完备、媲美原生App的Web阅读应用。在开发中,将各种知识点穿插应用,让你真实感受到一个明星产品开发的全过程,项目对阅读器有着较为深入的研究,对各种复杂功能有从原理到实现的详细教学。同时,项目提供一流的用户体验和交互水准,在实现功能之外带你探究各种优秀前端交互的设计和实现

适合人群
适合有一定前端开发经验,但是缺乏Vue.Js实战经验,对整体开发流程
及工具不够熟悉 ,进一步提升项目开发经验,并想掌握大厂交互设计
思路的同学

技术储备要求
建议先学习免费课程《快速入门Web阅读器开发》
了解Vue.Js 的基本语法,开发过简单的项目
掌握HTML/CSS/Js 基本用法,理解CSS盒子模型和flex布局
了解SCSS/Sass,对ES6的语法有一定了解
具有npm+Webpack使用经验,有Vue Cli 构建项目的经验

一、用户界面典范
1.自界说窗口
体系主题或自界说主题都必须在清单文件中设置。
一切经过 Activity.requestwindowFeature()办法修改窗口特性的恳求都必须在调用
Activity.setContentVIEw()之前完成。在此之后的一切改动都不会生效。
//设置自界说标题的布局资源
getwindow().setFeatureInt(Window.FEATURE_CUSTOM_Title,R.layout.custom_Title);
2.动态开关体系的UI控件
夜间方式 API Level 11
任何视图中调用 setsystemUIVisibility()
即可。而想要恢复到默许方式,需求以同样的方式调用 SYstem_UI_FLAG_VISIBLE。通
过调用 getsystemUIVisibility()并检查标识的当时状态就能够知道我们现在所在的方式了 。
XML 布局文件中的根元素是 LayoutInflater. inflate()回来的 VIEw 元素
3.屏幕分辨率
低分辨率(ldpi): 120 dpi 尺度是 mdpi 的 75%
中分辨率(mdpi): 160 dpi 原始的图片尺度
高分辨率(hdpi): 240 dpi 尺度是 mdpi 的 150%
超高分辨率(xhdpi): 320 dpi (API Level 8 新增) 尺度是 mdpi 的 200%
超级高(xxhdpi): 480 dpi (API Level 16 新增) 尺度是 mdpi 的 300%
4.锁定Activity方向
androID:screenorIEntation="portrait"或 androID:screenorIEntation=“landscape”
假如为 Activity 设置了 androID:screenorIEntation=“behind”, Activity 就会跟 Activity 栈中前一个 Activity 的方向保持一致
androID:configChanges=“orIEntation|keyboardHIDden” />
在一条赋值语句中能够注册多种变动,用“ |”符号将它们分隔即可。
5.d出菜单
也能够调用 Activity.openContextMenu()来触发任意视图的 ContextMenu,传入之前注
册的视图即可。
程序清单 2-29 自界说布局的 AlertDialog
public class CustomItemActivity extends Activity
implements DialogInterface.OnClickListener, VIEw.OnClickListener {
private static final String[] ZOnes = {“Pacific Time”, “Mountain Time”,
“Central Time”, “Eastern Time”, “Atlantic Time”};
private static final String[] OFFSETS =
{“GMT-08:00”, “GMT-07:00”, “GMT-06:00”, “GMT-05:00”, “GMT-04:00”};
button mbutton;
AlertDialog mActions;
@OverrIDe
protected voID onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setTitle(“Activity”);
mbutton = new button(this);
mbutton.setText(“Click for Time Zones”);
mbutton.setonClickListener(this);
ArrayAdapteradapter = new ArrayAdapter(this,
R.layout.List_item) {
@OverrIDe
public VIEw getVIEw(int position, VIEw convertVIEw, VIEwGroup parent) {
VIEw row = convertVIEw;
if(row == null) {
row = getLayoutInflater().inflate(R.layout.List_item,
parent, false);
}
TextVIEw name = (TextVIEw) row.findVIEwByID(R.ID.text_name);
TextVIEw detail = (TextVIEw) row.findVIEwByID(R.ID.text_detail);
name.setText(ZOnes[position]);
detail.setText(OFFSETS[position]);
return row;
}
@OverrIDe
public int getCount() {
return ZOnes.length;
}};
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setTitle(“Select Time Zone”);
builder.setAdapter(adapter, this);
//这儿的撤销动作只会让对话框消失,但在用户单击 Cancel 按钮时,也能够添加一个
//监听器来处理一些其他的 *** 作
builder.setNegativebutton(“Cancel”, null);
mActions = builder.create();
setContentVIEw(mbutton);
}
//这儿处理列表的挑选事件
@OverrIDe
public voID onClick(DialogInterface dialog, int which) {
String selected = ZOnes[which];
mbutton.setText(selected);
}
//这儿处理 button 的单击事件(d出对话框)
@OverrIDe
public voID onClick(VIEw v) {
mActions.show();
}
}
6.模仿home键
Intent intent = new Intent(Intent.ACTION_MAIN);
intent.addcategory(Intent.category_HOME);
startActivity(intent);
7.TextVIEw
SDK 中有一些很便利的预界说的用于格式化文本输入的 TextWatcher 实例
8.动画
AndroID SDK的AnimationUtils 类加载
滑入和渐显AnimationUtils.makeInAnimation()用布尔参数决议滑入的方向是左边仍是右侧向上
滑入和渐显 AnimationUtils.makeInChildBottomAnimation() 视图总是从屏幕的底部向上滑入
滑出和渐隐 AnimationUtils.makeOutAnimation() 用布尔参数决议滑入的方向是左边仍是右侧
渐隐 AnimationUtils.loadAnimation() 将 int 参数设为 androID.R.anim.fade_out
渐显 AnimationUtils.loadAnimation() 将 int 参数设为 androID.R.anim.fade_in
AlphaAnimation 以动画的守时改动视图的透明度。
RotateAnimation 以动画的方式改动视图的旋转角度。中心点是可装备的,默许是左上角。
ScaleAnimation 以动画的方式改动视图的缩放比例(巨细)。中心点是默许是左上角。
TranslateAnimation 以动画的方式改动视图的方位。
动画视图 VIEwPropertyAnimator
ObjectAnimator
在 XML 顶用标签界说 Drawable 时,实际上是创立了一个 GradIEntDrawable
方针。方针的形状能够是矩形、椭圆、线条或圆圈,最常见的布景形状是矩形。具体来说,
在运用矩形时,能够用下面这些参数界说形状:
● 角半径 界说 4 个角的半径,或是分别界说各个角的半径。
● 突变 线性、放射或 sweep 突变。两个或三个色彩值。方向能够是 45°的任何倍数(0 便是从左到右, 90 便是从下到上,以此类推)。
● 固定色彩 用一种色彩填充形状。 假如一同界说了突变的话,作用会受影响。
● 边线 方针形状的边界。 界说宽度和色彩。
● 巨细和 padding
XML 中色彩的种类约束是 3 种,可是 GradIEntDrawable 的构造函数中的色彩参数是一个整型数组int[],传递多少色彩都能够。
Activity 间的过渡动画, 能够运用 overrIDePendingTransition()
Fragment 的过渡动画,能够运用 onCreateAnimation()或 onCreateAnimator()
经过调用 setCustomAnimations()覆写单个 FragmentTransaction 的
过渡动画。
setCustomAnimations()必须在 add()、 replace()和其他动作办法之前调用,不然动画将不
会运行。

9.圆角遮罩
首先在 Canvas 中依据所需的圆角半径创立一个圆角矩形,然后以 PorterDuff.Mode.SRC_IN 为画笔在同一个 Canvas 上绘制源图,得到的便是带圆角的源图。
10.Dialog
呈现给用户的界面需求在旋转过程中保持状态,始终处于最前端,更好的办法是
运用 Activity。这样就能够经过各种生命周期回调办法来保存和读取状态。
11.自界说Enter键
androID:imeOptions
actionUnspecifIEd:默许值,依据设备的状况显现动作。
actionGo:在 Enter 键上显现 Go。
ActionSearch:在 Enter 键上显现 Search。
actionSend:在 Enter 键上显现 Send。
antionNext:在 Enter 键上显现 Next。
actionDone:在 Enter 键上显现 Done。
自界说用户按下按键时所触发的动作。重
载动作的默许行为需求给相应的视图加上 TextVIEw.OnEditorActionListener。
用 inputMethodManager.hIDeSoftinputFromWindow()办法能够让输入法管理器隐藏可见
的输入法。
12.ListvIEw
ExpandableListVIEw 控件及其适配器能够处理分节列表中的二维数据结构。
13.getPageWIDth()。
这个办法允许你在每个方位上设置图片页面巨细相关于 VIEwPager 页面巨细的百分比。默
认值为 1,前面的示例也没有改动该默许值。但假如要一次显现几个页面,能够经过调整
这个办法的回来值来完成

二、显现web信息
1.经过url显现的运用
拜访XX网站
经过web服务器显现实时更新的页面,能够动态更新
显现大资源图片,经过缩放来交互
2.显现本地资源
可用assets目录存储本地资源 file:///androID_asset
可显现string资源或变量中的原始HTML代码
3.经过WebvIEwClIEnt阻拦事件
WebVIEwClIEnt.shouldOverrIDeUrlLoading()回调来阻拦和监控用户的 Activity
shouldOverrIDeUrlLoading()会依据传入的 URL 决议是否要在 WebVIEw 中加
载内容, 防止用户脱离想要展现 的网站。
WebVIEw.addJavaScriptInterface()会为 JavaScript 绑定一个 Java 方针,这样就能够在
WebVIEw 中调用 Java 的办法。会存在JavaScript注入问题
4.下载图片
彻底在后台下载运用DownloadManager API service 支撑断点续传
DownloadManager.Request 恳求方针,它代表了下载的内容
Request.setAllowednetworkTypes():指定下载所运用的网络类型
Request.setAllowedOverRoaming():设定当设备处于漫游方式时是否要下载。
Request.setDescription():设置下载在体系告诉栏中显现的描述。
Request.setDestinationInExternalfilesDir():设置方针方位为外部存储器中的一个隐藏目录
Request.setDestinationInExternalPublicDir():设置方针方位为外部存储器中的一公共目录
Request.setDestinationUri():设置方针方位为坐落外部存储器中一个文件 Uri
三。通信
1.接纳短信
注册一个 broadcastReceiver 来监听收到的音讯,并在 onReceive()中处理它们。当收到一条短信时, *** 作体系会发送一个 action 值为 androID.provIDer.Telephony.SMS_RECEIVED
的播送 Intent。运用程序则能够注册一个 broadcastReceiver 过滤这个 Intent 并处理收到的
数据。接纳短信需求在 manifest 中声明 androID.permission.RECEIVE_SMS 权限。
2.蓝牙通信
蓝牙上的衔接是经过发现可用的“服务”,并经过一个 128 位的 UUID 衔接到相应的服务。
androID.permission.BLUetoOTH 权限。另外,想要改动蓝牙的可发现性以及启用/禁用蓝牙适配器,还要在 manifest 中声明androID.permission.BLUetoOTH_admin 权限
3.查询网络衔接状态
经过 ConnectivityManager 监控设备的网络衔接状态。
public boolean isNetworkReachable() {
ConnectivityManager mManage = (ConnectivityManager)context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo current = mManager.getActiveNetworkInfo();
if(current == null) {
return false;
}
return (current.getState() == NetworkInfo.State.CONNECTED);
}
判别链接类型
return (current.getType() == ConnectivityManager.TYPE_WIFI);
4.运用NFC传输数据
依据想要推送内容的巨细,有两种机制能够用来在两个设备间 Beam 数据。
第一种. 运用前台 Push 进行 Beam。假如运用 NFC 在设备间发送简略的内容, 能够运用前台推送机制来创立一个 Nfcmessage,它包含了一个或多个 NfcRecord 实例。
第二种,AndroID Application Record
5.运用 Beam 来发送大型图片文件
6.USB链接
端点: USB 设备的最小构件。运用程序最终便是经过衔接端点发送和接纳数据的。首要分4 种类型:
y *** 控传输:用于装备和状态指令。每个设备至少一个 *** 控端点,即“端点 0”,不会相关任何接口。
y 中断传输:用于小量的、高优先级的 *** 控指令。
y 批量传输:用于传输大数据。一般都是双向成对出现的(1 IN 和 1 OUT)。
同步传输:用于实时数据传输,如音频。编撰本书时最新的 AndroID SDK 还不支撑这个功能。
● 接口:端点的集合,用来表明一个“逻辑”设备 。
y 多个物理 USB 设备关于主机来说能够呈现为多个逻辑设备, 即经过露出接口来标识 。
● 装备:一个或多个接口的集合。 USB 强制规定一个设备在某一特守时间只能有一个装备是激活的。事实上,大都设备也就只有一个装备,并把它作为设备的 *** 作方式

四、设备硬件交互
1.定位
需求留意设备的电量以及尊重用户的志愿
GPS 回来的信息愈加精确(差错为几米),但需求的时间更长并且更耗电,
而网络方位一般精确到几千米,但速度更快并且省电
androID.permission.ACCESS_COARSE_LOCATION 或
androID.permission.ACCESS_FINE_LOCATION 权限
(1) 判别所需的方位信息源是否可用。假如不可用的话,决议是要求用户启用它仍是
测验其他的信息源。
(2) 用恰当的最小距离和更新时间距离注册设备方位的改变状况。
(3) 当不需求时,及时撤销对设备方位改变状况的注册,以节约电量。
2.地图方位
百度、高德、谷歌
3.拍摄相片和视频
将保存图片的文件方位指定为设备的外部存储器指定 androID.permission.
WRITE_EXTERNAL_STORAGE 权限。
在摄像头不用时及时调用Camera.release()办法在摄像头不用时及时调用Camera.release()办法
录音
private voID resetRecorder() {
//告诉录音机将运用设备的麦克作为音频输入源(AudioSource.MIC)
recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
recorder.setoutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
recorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAulT);
recorder.setoutputfile(path.getabsolutePath());
try {
recorder.prepare();
} catch (Exception e) {
e.printstacktrace();
}
}
经过 androID.speech 包中的类能够运用 AndroID 设备中内置的语音辨认技能。
4.传感器
运用 SensorManager 接纳来自于加速度计传感器继续的反馈数据
registerListener()的最后一个参数界说了更新频率。这儿挑选的是 SENSOR_DELAY_UI,它是接纳更新的最快频率,每次更新都会直接修改 UI。
每当传感器有新值更新,都会用 SensorEven 值一同调用已注册监听器的 onSensorChanged()办法。这个 SensorEvent 值包含了 X/Y/Z 轴上的加速度值。
罗盘传感器
设备的磁场传感器和加速度计一同确定用户面向的方向
运用 SensorManager 的 getorIEntation()得到用户在地球上的方向
5.从媒体内容得到截图的缩略图或其他元数据
MediaMetadataRetrIEver 读取媒体文件并回来有用的信息,能够读取和盯梢专辑或艺术家数据、或许内容数据本身,抓取该帧的截图

四。数据耐久化
1.存储、修改和显现用户设置及运用设置
PreferenceActivity 和 XML Preference 文件
2.读写文件
内部存储
受维护的用于读写文件数据的目录空间。
外部存储
外部挂载的用于读写文件数据的空间。
API Level 4 以上需求 WRITE_EXTERNAL_STORAGE 权限。一般都是设备的 SD 卡。
Assets
APK 中只读的受维护空间。用于放置不能/不该该被编译的本地资源。
3.共享数据
ContentProvIDer作为运用程序数据对外的接口,能够向外部恳求露出任何类型的运用程序数据,包含运用程序各种资源(包含 assets 下的资源)

五。与体系交互
1.告诉
经过一切的体系控件,如 Service、 broadcastReceiver 或许 Activity,都能够将一个通
知发送到 notificationmanager。
Notification.Style展现更多的告诉款式
2.创立粘性 *** 作
IntentService 会即将履行的使命(用 Intent表明)放到行列中,然后逐一处理每个恳求,全部处理完成后会终止自己。
3.启用其他运用程序
a。读取pdf文件
intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(file, “application/pdf”);
b、与好友共享内容
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setType(“text/plain”);
intent.putExtra(Intent.EXTRA_TEXT, update);
startActivity(Intent.createChooser(intent, “Share…”));
c。ShareActionProvIDer共享内容
依据用户运用习气,频频运用的选项会排到列表的最上方
androID:showAsAction=“ifRoom”
androID:Title=“Share”
androID:actionProvIDerClass=“androID.Widget.ShareActionProvIDer”/>
MenuItem item = menu.findItem(R.ID.menu_share);
ShareActionProvIDer provIDer = (ShareActionProvIDer) item.getActionProvIDer();
4.发动体系运用程序
a。浏览器
pageIntent.setAction(Intent.ACTION_VIEW);
pageIntent.setData(Uri.parse(“ http://WEB_ADDRESS_TO_VIEW” ));
b。电话拨号器
dialintent.setAction(Intent.ACTION_DIAL);
dialintent.setData(Uri.Parse(“ tel:8885551234” );
c。地图
mAPIntent.setAction(Intent.ACTION_VIEW);
mAPIntent.setData(Uri.parse(“ geo:latitude,longitude” ));
d。电子邮件
mailintent.setAction(Intent.ACTION_SEND);
mailintent.setType(“ message/rfc822” );
mailintent.putExtra(Intent.EXTRA_EMAIL, new String[] {“[email protected]”}); 收件人
mailintent.putExtra(Intent.EXTRA_CC, new String[] {“[email protected]”}); 抄送
mailintent.putExtra(Intent.EXTRA_BCC, new String[] {“[email protected]”}); 密件抄送
mailintent.putExtra(Intent.EXTRA_SUBJECT, “Email Subject”);
mailintent.putExtra(Intent.EXTRA_TEXT, “Body Text”);
mailintent.putExtra(Intent.EXTRA_STREAM, URI_TO_file); 附件
e、短音讯
smsIntent.setAction(Intent.ACTION_VIEW);
smsIntent.setType(“ vnd.androID-dir/mms-sms” );
smsIntent.putExtra(“ address” , “ 8885551234” );
smsIntent.putExtra(“ sms_body” , “ Body Text” );
f。联系人挑选器
pickIntent.setAction(Intent.ACTION_PICK);
pickIntent.setData(URI_TO_CONTACT_table);
g。Google Play
marketIntent.setAction(Intent.ACTION_VIEW);
marketIntent.setData(Uri.parse(“ market://details?ID=PACKAGE_name_HERE” ));

六。AndroID NDK和Renderscript
七。运用程序规划指南
1.规划经过滤的运用程序
2.规划高性能的运用程序
优化代码结构、少创立方针、减少浮点运算、运用 System.arraycopy()复制、
运用扩大版的循环(比方 for (Strings: strings) {})
3.规划快速呼应的运用程序
留意运用线程
4.规划无缝衔接的运用程序
不要丢掉数据,不要供给原始数据,发送告诉、用线程履行长时间 *** 作、防止ANR、扩展体系主题、规划运用多种分辨率的用户界面、留意网络判别、不要指定键盘布局、节约用电。
5.规划安全的运用程序

总结

以上是内存溢出为你收集整理的Vue 实战商业级读书Web APP 全面提升技能全部内容,希望文章能够帮你解决Vue 实战商业级读书Web APP 全面提升技能所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1055413.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存