nsis安装包_手把手教NIS Edit安装向导的使用

转自:http://blog.csdn.net/signjing/article/details/7855855

示例脚本解析:http://blog.csdn.net/signjing/article/details/7944160

参考来自:http://blog.csdn.net/rankun1/article/details/51242522

http://blog.163.com/weiming886521365@126/blog/static/3311507420133233756887/


手把手教NIS Edit安装向导的使用

需求的软件环境:

NSIS 2.46

HM NIS Edit 2.03

 

安装完上述两款软件后启动HM NIS Edit,如图:

点击“文件”-“新建脚本:向导”,如图:

弹出向导欢迎界面,点击“下一步”:

可以自定义应用程序名称,版本,出版人,网站等信息,点击“下一步”:

安装程序语言取消选择“English”,选择“SimpChinese”,点击“下一步”:

设置授权文件的路径,点击“下一步”:

向导中默认的许可文件路径为“c:\path\to\licence\YourSoftwareLicence.txt”,但事实上这个路径并不存在,因此设置授权文件的路径,但要确保路径是存在的。为此,在C:\util\nsis_exam\目录下创建了协议许可.rtf文件。

 

此次是为了演示安装向导的使用,因此不必深究.rtf中文件的内容,只需创建它,用office word编辑它,随意保存些文本即可,如:

应用程序列表中有默认的两个文件,实际制作安装包时,这两个文件往往不是我们需求的文件:

选中它们,利用“删除文件”按钮将其移除:

然后点击“添加目录树”按钮:

弹出目录编辑界面,通过浏览文件夹按钮选择目录,如图目录为“C:\Program Files\NSIS”,点击“确定”按钮:

待文件全部加载到应用程序文件列表,如图,点击下一步:

确认下应用程序的图标信息,点击下一步:

可以指定安装程序完成时要执行的程序文件,点击“下一步”:

10 可以指定解除安装程序属性,然后点击“下一步”:

11 勾选“保存脚本”、“转换文件路径到相关路径”,点击“完成”:

12 提示保存脚本窗口,为脚本命名,如图为“signjing安装示例.nsi”,点击“保存”按钮:

13 脚本保存后自动回到编辑器主界面:

 

14 点击“NSIS-“编译脚本”以编译脚本:

15 脚本开始编译,脚本编译时,可以通过日志窗格看到编译进程:

16 编译完成,在日志窗格会显示类似的信息:

17 在脚本的同目录下可以看到安装包Setup.exe已产生:

 

到此,利用安装向导制作的安装包就完成了,从认识NSIS到能做出安装包,这无疑是一个重大的改变,但我们的追求不能仅停留在这个层面,下一次将针对本次产生的脚本进行修改以实现一些安装包个性化的效果。


一些常见的问题:

1.问:在安装的过程中,如何执行BAT文件?

   答:按照上面向导生成的脚本,有这么一段脚本,注意我用红色标注的内容,红色的部分是在文件复制完成以后执行BAT文件的脚本,注意操作步骤,复制文件结束后,再执行,卸载的时候执行BAT文件顺序相反

Section "MainSection"SEC01

  SetOutPath "$INSTDIR\*.*"

  SetOverwrite ifnewer

  File /r "D:\ProgramFiles\HyperSnap6\*.*"

  ExecWait "$INSTDIR\install.bat"

SectionEnd


1)、ExecWait "$INSTDIR\nsis.bat"                                           //可以等待          不可以隐藏窗口 
2)、nsExec::Exec "$INSTDIR\nsis.bat"                                     //可以等待          可以隐藏窗口
3)、ExecShell Open "$INSTDIR\nsis.bat" "" SW_HIDE             // 不可以等待     可以隐藏窗口
4)、ExecCmd::exec "$INSTDIR\nsis.bat"                                  // 不可以等待     可以隐藏窗口  ( Pop $0、 ExecCmd::wait $0  等待)

 

2.问:如果修改安装文件和卸载文件的图标

   答:修改这部分脚本即可

!define MUI_ICON"${NSISDIR}\Contrib\Graphics\Icons\modern-install.ico"

!define MUI_UNICON"${NSISDIR}\Contrib\Graphics\Icons\modern-uninstall.ico"

nsis自带的有两个图标,我自己感觉稍微能好看一点点(汗,虽然还是很丑,好吧,凑合着用),修改后的

!define MUI_ICON"${NSISDIR}\Contrib\Graphics\Icons\Orange-install.ico"

!define MUI_UNICON"${NSISDIR}\Contrib\Graphics\Icons\Orange-uninstall.ico"

 3. 如何注册dll,ocx

在安装Section和卸载Section中分别写下面的注册和反注册代码

方法一:利用RegDLL/UnRegDLL

SetOutPath "$INSTDIR"

; 注册
RegDLL "$INSTDIR\test.dll"
;反注册
UnRegDLL "$INSTDIR\test.dll"

方法二:利用ExecWait,该函数阻塞,返回前不会执行下面代码

;注册。注意:不加/s会弹出注册成功的弹出框。

ExecWait 'regsvr32 /s "$INSTDIR\test.dl"'

;反注册

ExecWait 'regsvr32 /s /u "$INSTDIR\test.dl"'

方法三:利用ExecCmd::exec+DOS脚本(偏方)
ExecCmd::exec "自己写的bat或cmd等脚本"  ;脚本里写注册,如同方法二中那样






  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AnimationTabLayout是一个可以实现选项卡布局的Android库,它提供了许多不同的选项卡切换动画,包括淡入淡出、旋转、缩放等等。在Niuniu_NSIS_SetupSkin中,我们可以使用AnimationTabLayout来实现安装界面的轮播效果。 首先,我们需要在项目的build.gradle文件中添加以下依赖项: ``` dependencies { implementation 'com.gauravk.bubblenavigation:bubblenavigation:1.0.7' } ``` 然后,在安装界面的布局文件中,我们可以定义一个AnimationTabLayout来作为选项卡布局,如下所示: ``` <com.gauravk.bubblenavigation.BubbleNavigationConstraintView android:id="@+id/bottom_navigation_view_constraint" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" app:layout_constraintBottom_toBottomOf="parent" app:menuResource="@menu/bottom_navigation_items" /> <com.gauravk.bubblenavigation.BubbleNavigationLinearView android:id="@+id/top_navigation_view_linear" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="top" app:layout_constraintTop_toTopOf="parent" app:menuResource="@menu/top_navigation_items" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_home" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_home_black_24dp" app:title="@string/home" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_search" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_search_black_24dp" app:title="@string/search" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_notifications" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_notifications_black_24dp" app:title="@string/notifications" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_profile" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_person_black_24dp" app:title="@string/profile" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_settings" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_settings_black_24dp" app:title="@string/settings" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_help" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_help_black_24dp" app:title="@string/help" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_about" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_info_black_24dp" app:title="@string/about" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_exit" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_exit_to_app_black_24dp" app:title="@string/exit" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_feedback" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_feedback_black_24dp" app:title="@string/feedback" /> <com.gauravk.bubblenavigation.BubbleToggleView android:id="@+id/btn_share" android:layout_width="wrap_content" android:layout_height="wrap_content" app:icon="@drawable/ic_share_black_24dp" app:title="@string/share" /> ``` 其中,我们使用了BubbleNavigationConstraintView和BubbleNavigationLinearView来实现选项卡布局,同时添加了多个BubbleToggleView作为选项卡按钮。 接下来,在安装界面的Java代码中,我们可以使用AnimationTabLayout的setSelectedChangeListener方法来实现选项卡切换时的动画效果,如下所示: ``` bubbleNavigationConstraintView.setNavigationChangeListener(new BubbleNavigationChangeListener() { @Override public void onNavigationChanged(View view, int position) { viewPager.setCurrentItem(position, true); } }); bubbleNavigationLinearView.setNavigationChangeListener(new BubbleNavigationChangeListener() { @Override public void onNavigationChanged(View view, int position) { viewPager.setCurrentItem(position, true); } }); viewPager.setAdapter(new SectionsPagerAdapter(getSupportFragmentManager())); viewPager.setOffscreenPageLimit(5); viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageSelected(int position) { bubbleNavigationConstraintView.setCurrentActiveItem(position); bubbleNavigationLinearView.setCurrentActiveItem(position); } @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageScrollStateChanged(int state) { } }); ``` 在这段代码中,我们首先使用setNavigationChangeListener方法来设置选项卡切换时的监听器,然后使用setCurrentItem方法来设置当前选项卡的位置。接着,我们使用setAdapter方法来设置选项卡的适配器,并使用addOnPageChangeListener方法来监听选项卡的滑动事件。在onPageSelected方法中,我们使用setCurrentActiveItem方法来设置当前选项卡的位置。 通过以上步骤,我们就可以使用AnimationTabLayout来实现Niuniu_NSIS_SetupSkin的安装界面轮播效果了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值