安卓app源码和设计报告——麻雀笔记-ag凯发k8国际

目录
安卓应用程序开发背景3
1.1开发背景3
1.2开发环境4
二 安卓应用程序开发理论与方法4
三 记事本应用程序的设计与实现5
3.1 拟解决的问题及目标5
3.2 总体设计6
3.3 详细设计与编码实现6
四 总结23
一 安卓应用程序开发背景
1.1开发背景
1.智能手机的市场
(1)功能多样化的智能手机挑战全球pc出货量
移动互联网时代的来临,直接促进了搭载智能操作系统、具有强大扩展性的智能手机、平板电脑等移动终端产业的蓬勃发展。来自美国最大的风险投资机构kpcb的数据显示,全球智能手机出货量正在以远高于台式电脑、笔记本电脑出货量的速度快速增长,该机构预计2011年全球智能手机出货量将达到4.13亿,超过台式电脑与笔记本电脑出货量的总和。
(2)智能手机的用户使用数量正在高速增长。据市场调研机构gartner信息,2011年全球智能手机的总出货量将会达到4.68亿部,相比2010年实现了57.7%的增长,而谷歌android操作系统将会在今年之内成为全球最大的智能手机操作系统。另外,全球市场调研机构idc预计未来5年中国手机市场上,智能手机替代传统功能手机的趋势将日益明显,未来5年中国智能手机市场复合增长率将达到34.1%,人们对it设备智能化的向往是这一增长率能够实现的主要因素,并且与其他国家相比,中国智能手机市场的发展空间更加广阔。
(3)操作系统格局预测:android有望成为智能手机市场主导力量
搭载android操作系统的智能手机目前已经成为市场上最炙手可热的智能产品。来自美国市场研究机构gartner的数据显示,android操作系统所占的市场份额从2008年的0.5%急剧增长到2011年的15.94%。开放的源代码和零成本已经让android在全世界范围内受到青睐并迅速获得了主要手机厂商和数百万软件开发者的支持,gartner预计,未来android系统的市场份额有望超过其他操作系统,从而成为全球第一大智能手机操作系统。
2.安卓手机介绍
安卓手机指的是用android操作系统的手机。安卓(android)是基于linux内核的操作系统,是google公司在2007年11月5日公布的手机操作系统。
同样都是手机上面用的智能系统,安卓的系统是新生系统,界面更为华丽,开源性更强,当然因为是新生系统,所以在第三方软件方面暂时还不太多。因此,安卓应用程序的需求还是很迫切的。
3.软件人才需求
据业内统计,目前国内的android研发人才缺口至少30万。由于目前android技术较新,无论是相关书籍、培训还是大学教育,都处于初级阶段,因此android人才短期将供不应求。从长期来看,随着各种移动应用和手机游戏等内容需求日益增加,也将激励大中小型手机应用开发商加大对android应用的开发力度,因此android人才的就业前景也非常广泛。
综上所述,在这样的背景下,安卓有很强的生命力。同时,作为一个新生的系统,其应用程序目前并不多,安卓应用程序的需求还是很迫切的,安卓研发人才的缺口还很大。这些都促进了我们学习开发安卓应用程序。
1.2开发环境
安卓应用程序开发环境如下:
①jdk1.8
②android studio 4.0
android sdk
二 安卓应用程序开发理论与方法

  1. butterknife
    butterknife 是一个专注于 android 系统的 view 注入框架,以前总是要写很多 findviewbyid 来找到 view 对象,有了 butterknife 可以很轻松地省去这些步骤。使用 butterknife 对性能基本没有损失,因为 butterknife 用到的注解并不是在运行时反射的,而是在编译的时候生成新的 class。项目集成起来特别方便,使用起来也特别简单。
    butterknife 的优势:
    强大的 view 绑定和 click 事件处理功能,简化代码,提升开发效率
    方便地处理 adapter 里的 viewholder 绑定问题
    运行时不会影响 app 效率,使用配置方便
    代码清晰,可读性强
  2. sharedpreferences
    sharedpreferences 是使用键值对的方式来存储数据的。当保存一条数据的时候,需要给这条数据提供一个对应的键,这样在读取数据的时候就可以通过这个键把相应的值取出来。而且 sharedpreferences 还支持多种不同的数据类型存储。
  3. sqlite ormlite
    sqlite 是一款轻量级的关系型数据库,它的运算速度非常快,占用资源很少,通常只需要几百 kb 的内存就足够了,因而特别适合在移动设备上使用。sqlite 不仅支持标准的 sql 语法,还遵循了数据库的 acid 事务,所以只要以前是用过其他的关系型数据库,就可以很快地上手 sqlite。
    orm(全称 object relation mapping)叫做对象关系映射,是一种程序设计技术,用于实现面向对象编程语言中不同类型系统的数据之间的转换。它可以直接将 bean 文件转换成数据库中的表,bean 中的属性就是表的列,它将繁琐的数据库操作封装成一个 dao 类,使用 dao 类和 bean 可以直接对数据库进行操作,大多数的方法参数只有一个 bean 对象。
  4. 多线程编程 handler message
    handler 顾名思义也就是处理者的意思,它主要是用于发送和处理消息的。发送消息一般是使用 handler 的 sendmessage()方法,而发出的消息经过一系列的辗转处理后,最终会传递到 handler 的 handlemessage()方法中。
    message 是在线程之间传递的消息,它可以在内部携带少量的信息,用于在不同线程之间交换数据。除了 what 字段,message 还可以使用 arg1 和 arg2 字段来携带一些整型数据,使用 obj 字段携带一个 object 对象。
  5. glide
    glide 是一款快速高效的开源 android 媒体管理和图片加载框架,它将媒体解码、内存和磁盘缓存以及资源池打包成一个简单易用的界面。
    glide 支持抓取、解码和显示视频图片、图像和动态 gif。glide 包括一个灵活的 api,允许开发人员插入几乎任何网络堆栈。默认情况下,glide 使用了一个定制的基于 httpurlconnection 的堆栈,但也包含了可插入谷歌的 volley 项目或 square 的 okhttp 库的实用程序库。
    glide 的主要功能是尽可能平滑快速地滚动任何类型的图像列表,但它也适用于几乎任何需要获取、调整大小和显示远程图像的情况。
  6. recyclerview 控件
    recyclerview 是一个增强版的 listview,不仅可以轻松实现和 listview 同样的效果,还优化了 listview 中存在的各种不足之处。同时 recyclerview 支持横向滚动和瀑布流布局
  7. fragment viewpager

fragment 是一种可以嵌入在 activity 当中的 ui 片段,它能让程序更加合理和充分地利用大屏幕的空间,因而在平板上应用得非常广泛。它和 activity 同样都能包含布局,同样都有自己的生命周期。甚至可以理解成一个迷你的 activity。
viewpager 是 android 扩展包 v4 包中的类,这个类可以让用户左右切换当前的 view。viewpager 类直接继承了 viewgroup 类,因此它一个容器类,可以添加其他的 view 类 viewpager 类需要一个 pageradapter 适配器类给它提供数据(类似 recyclerview)。
viewpager 经常和 fragment 一起使用,并且官方还提供了专门的 fragmentpageradapter 类供 viewpager 使用。
三 记事本应用程序的设计与实现
3.1 拟解决的问题及目标
一个简单的记事本应用,在人们繁忙的时候更快速的记笔记,程序要实现的目标有如下几个:

  1. 登录注册
  2. 笔记顶置
  3. 开始游戏笔记增删查改

3.2 总体设计
1、记事本操作流程
先注册一个账号,登录进去,可以添加笔记,编辑笔记,顶置笔记,查找笔记
3.3 详细设计与编码实现

  1. 记事本界面

安卓app源码和设计报告——麻雀笔记


注册界面

安卓app源码和设计报告——麻雀笔记


新建笔记界面

安卓app源码和设计报告——麻雀笔记


编辑界面


个人信息界面

  1. 核心代码如下:

registeractivity类
public class registeractivity extends appcompatactivity {

@bindview(r.id.btn_register)
button btnregister;
@bindview(r.id.
btn_reset)
button btnreset;
@bindview(r.id.
check_hide_pwd_reg)
checkbox checkhidepwdreg;
@bindview(r.id.
check_hide_pwd_reg2)
checkbox checkhidepwdreg2;
@bindview(r.id.
edit_username_reg)
edittext editusernamereg;
@bindview(r.id.
edit_confirm_pwd_reg)
edittext editconfirmpwdreg;
@bindview(r.id.
edit_email_reg)
edittext editemailreg;
@bindview(r.id.
edit_password_reg)
edittext editpasswordreg;

sharedpreferenceutil spu;
private static final string tag = "registeractivity";
private userdao userdao;
private string textusername;
private string textpassword;
private string textconfirmpwd;
private string textemail;

@override
protected void oncreate(bundle savedinstancestate) {
super.oncreate(savedinstancestate);
setcontentview(r.layout.activity_register);
butterknife.
bind(this);
userdao = new userdao(this);
spu = sharedpreferenceutil.
getinstance(this);
}

@onclick({r.id.btn_register, r.id.btn_reset, r.id.check_hide_pwd_reg, r.id.check_hide_pwd_reg2})
public void onviewclicked(view view) {
switch (view.getid()) {
case r.id.
btn_register:
// 检验非空
if (isnotempty()) {
// 获得用户输入
getedittext();
// 检验密码
if (comparepwd()) {
// 检查邮箱格式
if (checkemail()) {
// 检查邮箱是否可用
if (checkonlyemail()) {
insertuserintodb();
queryall();
intent intent = new intent(registeractivity.this, mainactivity.class);
intent.putextra(constant.
has_registered, true);
startactivity(intent);
finish();
} else {
toast.
maketext(this, "邮箱已经被使用", toast.length_short).show();
}
} else {
toast.
maketext(this, "邮箱格式错误", toast.length_short).show();
}
} else {
toast.
maketext(this, "两次输入的密码不一致", toast.length_short).show();
}
} else {
toast.
maketext(this, "用户名或密码不能为空", toast.length_short).show();
}
break;
case r.id.
btn_reset:
editusernamereg.settext("");
editpasswordreg.settext("");
editconfirmpwdreg.settext("");
editemailreg.settext("");
break;
case r.id.
check_hide_pwd_reg:
if (checkhidepwdreg.ischecked()) {
// 将密码显示出来
editpasswordreg.settransformationmethod(hidereturnstransformationmethod.
getinstance());
} else {
// 隐藏密码
editpasswordreg.settransformationmethod(passwordtransformationmethod.
getinstance());
}
// 将光标移动到文本最后
editpasswordreg.setselection(editpasswordreg.gettext().tostring().length());
break;
case r.id.
check_hide_pwd_reg2:
if (checkhidepwdreg2.ischecked()) {
// 将密码显示出来
editconfirmpwdreg.settransformationmethod(hidereturnstransformationmethod.
getinstance());
} else {
// 隐藏密码
editconfirmpwdreg.settransformationmethod(passwordtransformationmethod.
getinstance());
}
// 将光标移动到文本最后
editconfirmpwdreg.setselection(editconfirmpwdreg.gettext().tostring().length());
break;
default:
break;
}
}

/**
* 检验输入非空
*
* @return
*/
public boolean isnotempty() {
return !"".equals(editusernamereg.gettext().tostring()) &&
!"".equals(editpasswordreg.gettext().tostring()) &&
!"".equals(editconfirmpwdreg.gettext().tostring());
}

/**
* 从控件中得到输入值
*/
public void getedittext() {
textusername = editusernamereg.gettext().tostring();
textpassword = editpasswordreg.gettext().tostring();
textconfirmpwd = editconfirmpwdreg.gettext().tostring();
textemail = editemailreg.gettext().tostring();
}

/**
* 检查邮箱是否可用
*
* @return
*/
public boolean checkonlyemail() {
list userbeans = userdao.queryforwhat("email", textemail);
return userbeans.size() == 0;
}

/**
* 验证两次输入的密码是否一致
*
* @return
*/
public boolean comparepwd() {
return textpassword.equals(textconfirmpwd);
}

/**
* 检查邮箱格式
*
* @return
*/
public boolean checkemail() {
matcher emailmatcher = constant.
email_pattern.matcher(textemail);
return emailmatcher.matches();
}

/**
* 向数据库表插入数据
*/
public void insertuserintodb() {
userbean userbean = new userbean(textusername, textpassword, textemail);
userdao.insert(userbean);
// 同时存到sp中
spu.putstring(constant.
user_name, textusername);
spu.putstring(constant.
password, textpassword);
}

/**
* 查询表中所有数据
*/
public void queryall() {
list userbeans = userdao.queryall();
for (int i = 0; i < userbeans.size(); i ) {
log.
d(tag, "queryall: " userbeans.get(i).tostring());
}
}
}
homeactivity类
public class homeactivity extends appcompatactivity implements navigationview.onnavigationitemselectedlistener {

@bindview(r.id.toolbar)
toolbar toolbar;
@bindview(r.id.
btn_top)
radiobutton btntop;
@bindview(r.id.
btn_add)
radiobutton btnadd;
@bindview(r.id.
btn_all)
radiobutton btnall;
@bindview(r.id.
dock_radio_group)
radiogroup dockradiogroup;
@bindview(r.id.
drawer_layout)
drawerlayout drawerlayout;
@bindview(r.id.
nav_view)
navigationview navview;

private static final string tag = "homeactivity";
actionbar actionbar;
fragment fragment;
fragmentmanager manager = getsupportfragmentmanager();
fragmenttransaction transaction = manager.begintransaction();
sharedpreferenceutil spu;
private userdao userdao;

@override
protected void oncreate(bundle savedinstancestate) {
super.oncreate(savedinstancestate);
setcontentview(r.layout.activity_home);
butterknife.
bind(this);
userdao = new userdao(this);
spu = sharedpreferenceutil.
getinstance(this);
initview();
}

/**
* 初始化控件
*/
public void initview() {
// 工具栏
toolbar.settitle(r.string.
app_name);
settitlecenter(toolbar);
setsupportactionbar(toolbar);
actionbar = getsupportactionbar();
if (actionbar != null) {
actionbar.setdisplayhomeasupenabled(true);
actionbar.sethomeasupindicator(r.drawable.
icon_setting);
}
// 抽屉
viewgroup.layoutparams params = navview.getlayoutparams();
params.width = getresources().getdisplaymetrics().widthpixels / 2;
navview.setlayoutparams(params);
navview.setnavigationitemselectedlistener(this);
// 抽屉中的header
view headerview = navview.getheaderview(0);
textview textusername = headerview.findviewbyid(r.id.
header_user_name);
textview textemail = headerview.findviewbyid(r.id.
header_email);
textusername.settext(spu.getstring(constant.
user_name));
textemail.settext(getemail());
// 默认加载置顶fragment
fragment = new topfragment();
transaction.replace(r.id.
view_pager, fragment, constant.top_tag);
transaction.commit();
}

/**
* 单选按钮监听器 用来切换fragment
*
* @param view
* @param ischanged
*/
@oncheckedchanged({r.id.
btn_add, r.id.btn_all, r.id.btn_top})
public void oncheckedchanged(compoundbutton view, boolean ischanged) {
transaction = manager.begintransaction();
switch (view.getid()) {
case r.id.
btn_top:
if (ischanged) {
fragment = new topfragment();
transaction.replace(r.id.
view_pager, fragment, constant.top_tag);
transaction.commit();
constant.
page_state = "top";
}
break;
case r.id.
btn_add:
if (ischanged) {
fragment = new addfragment();
transaction.replace(r.id.
view_pager, fragment, constant.add_tag);
transaction.commit();
}
break;
case r.id.
btn_all:
if (ischanged) {
fragment = new allfragment();
transaction.replace(r.id.
view_pager, fragment, constant.list_tag);
transaction.commit();
constant.
page_state = "all";
}
break;
default:
break;
}
}

/**
* 获得登录用户的邮箱
*
* @return
*/
public string getemail() {
list userbeans = userdao
.querybyusernameandpassword(spu.getstring(constant.
user_name), spu.getstring(constant.password));
return userbeans.get(0).getemail();
}

/**
* 抽屉中菜单的点击事件
*
* @param item
* @return
*/
@override
public boolean onnavigationitemselected(@nonnull menuitem item) {
drawerlayout.closedrawers();
switch (item.getitemid()) {
case r.id.
nav_change_pwd:
dialogutil.
editinfodialog(this, spu.getint(constant.user_id));
break;
case r.id.
nav_dismiss:
dialogutil.
dismissdialog(this, spu.getint(constant.user_id));
break;
case r.id.
nav_exit:
spu.putboolean(constant.
auto_login, false);
intent intent = new intent(homeactivity.this, mainactivity.class);
startactivity(intent);
finish();
break;

default:
break;
}
return true;
}

/**
* toolbar的menu
*
* @param menu
* @return
*/
@override
public boolean oncreateoptionsmenu(menu menu) {
getmenuinflater().inflate(r.menu.
toolbar_menu, menu);
seticonsvisible(menu, true);
return true;
}

/**
* 重写toolbar上菜单点击事件
* 按照条件查找
*
* @param item
* @return
*/
@override
public boolean onoptionsitemselected(@nonnull menuitem item) {
switch (item.getitemid()) {
case r.id.
search_title:
dialogutil.
searchtitledialog(this);
break;
case r.id.
search_content:
dialogutil.
searchcontentdialog(this);
break;
case r.id.
search_category:
dialogutil.
searchcategorydialog(this);
break;
case android.r.id.
home:
drawerlayout.opendrawer(gravitycompat.
start);
break;
default:
break;
}
return true;
}

/**
* toolbar标题居中
*
* @param toolbar
*/
public void settitlecenter(toolbar toolbar) {
string title = "title";
final charsequence originaltitle = toolbar.gettitle();
toolbar.settitle(title);
for (int i = 0; i < toolbar.getchildcount(); i ) {
view view = toolbar.getchildat(i);
if (view instanceof textview) {
textview textview = (textview) view;
if (title.equals(textview.gettext())) {
textview.setgravity(gravity.
center);
toolbar.layoutparams params = new toolbar.layoutparams(toolbar.layoutparams.
wrap_content, toolbar.layoutparams.match_parent);
params.gravity = gravity.
center;
textview.setlayoutparams(params);
}
}
toolbar.settitle(originaltitle);
}
}

/**
* menu显示图标
*
* @param menu
* @param flag
*/
private void seticonsvisible(menu menu, boolean flag) {
// 判断menu是否为空
if (menu != null) {
try {
// 如果不为空,就反射拿到menu的setoptionaliconsvisible方法
method method = menu.getclass().getdeclaredmethod("setoptionaliconsvisible", boolean.
type);
// 暴力访问该方法
method.setaccessible(true);
// 调用该方法显示icon
method.invoke(menu, flag);
} catch (exception e) {
e.printstacktrace();
}
}
}
findpwdactivity类
public class findpwdactivity extends appcompatactivity {

@bindview(r.id.btn_confirm_find)
button btnconfirmfind;
@bindview(r.id.
btn_reset_find)
button btnresetfind;
@bindview(r.id.
edit_confirm_pwd_find)
edittext editconfirmpwdfind;
@bindview(r.id.
edit_password_find)
edittext editpasswordfind;
@bindview(r.id.
edit_email_find)
edittext editemailfind;
@bindview(r.id.
check_hide_pwd_find)
checkbox checkhidepwdfind;
@bindview(r.id.
check_hide_pwd_find2)
checkbox checkhidepwdfind2;

private static final string tag = "findpwdactivity";
private userdao userdao;
private string textpassword;
private string textconfirmpwd;
private string textemail;

@override
protected void oncreate(bundle savedinstancestate) {
super.oncreate(savedinstancestate);
setcontentview(r.layout.activity_find_pwd);
butterknife.
bind(this);
userdao = new userdao(this);
}

@onclick({r.id.btn_confirm_find, r.id.btn_reset_find, r.id.check_hide_pwd_find, r.id.check_hide_pwd_find2})
public void onviewclicked(view view) {
switch (view.getid()) {
case r.id.
btn_confirm_find:
// 检查非空
if (isnotempty()) {
// 获得用户输入
getedittext();
// 检查邮箱格式
if (checkemail()) {
// 检查两次输入的密码是否一致
if (comparepwd()) {
// 更新密码
if (updatepwdfromdb()) {
// 跳转登录界面
intent intent = new intent(findpwdactivity.this, mainactivity.class);
startactivity(intent);
findpwdactivity.this.finish();
}
} else {
toast.
maketext(this, "两次输入的密码不一致", toast.length_short).show();
}
} else {
toast.
maketext(this, "邮箱格式错误", toast.length_short).show();
}
} else {
toast.
maketext(this, "邮箱或密码不能为空", toast.length_short).show();
}
break;
case r.id.
btn_reset_find:
// 清空输入
editpasswordfind.settext("");
editconfirmpwdfind.settext("");
editemailfind.settext("");
break;
case r.id.
check_hide_pwd_find:
if (checkhidepwdfind.ischecked()) {
// 将密码显示出来
editpasswordfind.settransformationmethod(hidereturnstransformationmethod.
getinstance());
} else {
// 隐藏密码
editpasswordfind.settransformationmethod(passwordtransformationmethod.
getinstance());
}
// 将光标移动到文本最后
editpasswordfind.setselection(editpasswordfind.gettext().tostring().length());
break;
case r.id.
check_hide_pwd_find2:
if (checkhidepwdfind2.ischecked()) {
// 将密码显示出来
editconfirmpwdfind.settransformationmethod(hidereturnstransformationmethod.
getinstance());
} else {
// 隐藏密码
editconfirmpwdfind.settransformationmethod(passwordtransformationmethod.
getinstance());
}
// 将光标移动到文本最后
editconfirmpwdfind.setselection(editconfirmpwdfind.gettext().tostring().length());
break;
default:
break;
}
}

/**
* 检验输入非空
*
* @return
*/
public boolean isnotempty() {
return !"".equals(editpasswordfind.gettext().tostring()) &&
!"".equals(editconfirmpwdfind.gettext().tostring()) &&
!"".equals(editemailfind.gettext().tostring());
}

/**
* 从控件中得到输入值
*/
public void getedittext() {
textpassword = editpasswordfind.gettext().tostring();
textconfirmpwd = editconfirmpwdfind.gettext().tostring();
textemail = editemailfind.gettext().tostring();
log.
d(tag, "getedittext: " textemail);
}

/**
* 检查邮箱格式
*
* @return
*/
public boolean checkemail() {
matcher emailmatcher = constant.
email_pattern.matcher(textemail);
return emailmatcher.matches();
}

/**
* 验证两次输入的密码是否一致
*
* @return
*/
public boolean comparepwd() {
return textpassword.equals(textconfirmpwd);
}

/**
* 修改数据库中的密码
*
* @return 邮箱是否存在
*/
public boolean updatepwdfromdb() {
list userbeans = userdao.queryforwhat("email", textemail);
if (userbeans.size() != 0) {
userbean user = userbeans.get(0);
user.setpassword(textpassword);
userdao.update(user);
return true;
} else {
toast.
maketext(this, "邮箱错误", toast.length_short).show();
return false;
}
}
}

}
public void onleaveapplication(ad arg0) {
// todo auto-generated method stub

}
public void onfailedtoreceivead(ad arg0, errorcode arg1) {
// todo auto-generated method stub
}
public void ondismissscreen(ad arg0) {
// todo auto-generated method stub
}
});
view gamemessage = findviewbyid(r.id.gamemessage);
int[] data = getsettingdata();
textview levelmessage = (textview)findviewbyid(r.id.level_message);
levelmessage.settext("score: " data[0] "nbest: " data[1]);
gamemessage.setonclicklistener(new view.onclicklistener() {
public void onclick(view arg0) {
intent intent = new intent(loadingactivity.this, gamebirdactivity.class);
intent.setflags(intent.flag_activity_clear_top);

startactivity(intent);

finish();
}
});
}
private int[] getsettingdata() {
sharedpreferences gb_settings = getsharedpreferences(gamebirdactivity.gamebirdsettingsfile, 0);
int last = gb_settings.getint(gamebirdactivity.settings_levellast, 0);
int top = gb_settings.getint(gamebirdactivity.settings_leveltop, 0);

return new int[]{last, top};
}
public boolean onkeydown(int keycode, keyevent event) {
if (keycode == keyevent.keycode_back) {
try{
gamebirdactivity.instance.finish();
}catch(exception e){}
finish();
system.exit(0);
return true;
}
return super.onkeydown(keycode, event);
}
}
四 总结

ag凯发k8国际的版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年5月6日 下午6:58
下一篇 2024年5月6日 下午7:10

相关推荐

  • 1565亿元!史上最烧钱攻关项目,它到底是要做啥?(最烧钱的项目)

    可控核聚变模拟太阳中的核反应,被视为理想的清洁能源,目前该领域在建的规模最大的研发项目——国际热核聚变实验堆(iter)也被寄予厚望。它将帮助科学家延长可控核聚变反应的持续时间,测…

    科研百科 2024年4月1日
    108
  • 低代码开发平台产品经理

    低代码开发平台产品经理是现代软件开发领域中的重要角色之一。随着技术的不断进步和市场需求的变化,低代码开发平台产品经理的职责也在不断演变和扩展。 首先,低代码开发平台产品经理需要对市…

    科研百科 2024年3月1日
    136
  • 项目进度管理小软件

    项目进度管理小软件 随着现代项目管理的日益普及,项目进度管理已经成为了项目成功的关键之一。然而,传统的手动项目进度管理方式已经无法满足现代项目的高并发和快速变化的需求。因此,开发一…

    科研百科 2024年9月4日
    42
  • 【提示】“一网通办”企业专属网页 “我的项目”专栏今天上线啦!

    市大数据中心说,“一网通办”平台企业专属网页“我的项目”专栏,将为所有项目法人提供一个“快速掌握项目各类批复信息、提出政务服务事项办理申请、报送项目相关数据”的平台,助力开展项目前…

    科研百科 2024年4月24日
    67
  • 施工进度管理内容

    施工进度管理是建筑工程项目管理中至关重要的一环,关系到工程的顺利进行和按时交付。本文将介绍施工进度管理的重要性、方法和技巧,为建筑工程项目管理提供参考和借鉴。 施工进度管理的重要性…

    科研百科 2024年8月13日
    62
  • 杭州市科研项目申报 杭州课题申报

    杭州市科研项目申报 | 杭州课题申报 随着城市化进程的加速,科研项目申报已经成为杭州市科技创新的重要方式之一。作为全国著名的科技城市,杭州市拥有丰富的科研资源和优秀的科技创新环境。…

    科研百科 2024年7月29日
    53
  • 科技项目经费

    科技项目经费:推动科技发展的关键 科技项目经费是推动科技发展的关键。随着科技的不断发展,科技项目经费的重要性也越来越凸显。科技项目经费可以帮助研究人员获得所需的资金,用于实验和研究…

    科研百科 2024年7月12日
    70
  • 支部委员任职条件 党龄

    支部委员任职条件:党龄 作为一名党员,担任支部委员是组织给予我们的一项光荣使命,也是党员身份的一种体现。担任支部委员需要具备哪些任职条件呢?下面,我们来详细了解一下。 首先,作为一…

    科研百科 4天前
    0
  • 人查查免费社工库

    人查查免费社工库 随着网络的发展,社工库成为了一个公开的、资源共享的数据库,人们可以通过它获取各种个人信息,包括姓名、地址、电话、电子邮件等等。但是,这些信息的获取是非法的,并且可…

    科研百科 2024年10月31日
    8
网站地图