社区
数据库(包含打印,安装,报表)
帖子详情
用VB代码,从SQL数据库中提出一个图片字段,并在窗体中显示出来,求高手指点!
Thinking_More
2006-03-08 04:24:57
SQL数据库中图片字段为image,(二进制)
...全文
91
4
打赏
收藏
用VB代码,从SQL数据库中提出一个图片字段,并在窗体中显示出来,求高手指点!
SQL数据库中图片字段为image,(二进制)
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
迈克揉索芙特
2006-03-08
打赏
举报
回复
要引用ADO组件的
Thinking_More
2006-03-08
打赏
举报
回复
New ADODB.Stream 系统提示说,类型未定义!
迈克揉索芙特
2006-03-08
打赏
举报
回复
http://www.chenoe.com/blog/blogview.asp?logID=1910
迈克揉索芙特
2006-03-08
打赏
举报
回复
http://www.chenoe.com/blog/blogview.asp?logID=1
http://www.chenoe.com/blog/blogview.asp?logID=1
VB
实现多表查询的模块实例.rar
一个
VB
6.0写的
数据库
查询向导,
VB
实现多表查询的模块实例,
数据库
SQL
SERVER,
数据库
文件已经为你准备好,在database目录下,测试前请自己附加好,程序使用说明: 单表查询: 1.在查询
窗体
中
单击鼠标右建,弹出“添加”菜单。 2.单击“添加”菜单在查询
窗体
中
动态创建表
字段
显示
窗口。 3.在表
字段
显示
窗口
中
选
中
显示
字段
后在条件设置容器
中
设置相应的查询条件 多表查询: 1.在查询
窗体
中
单击鼠标右建,弹出“添加”菜单。 2.单击“添加”菜单在查询
窗体
中
动态创建表
字段
显示
窗口。 3.在表
字段
显示
窗口
中
双击某节点,将相应的
字段
设置为关系
字段
。单击鼠标右键取消关系
字段
4.在表
字段
显示
窗口
中
选
中
显示
字段
后在条件设置容器
中
设置相应的查询条件
c#、
vb
、多线程、委托、实现等待
窗体
Demo
项目需要个等待
窗体
,网上没找到现成的,Dev及第三方控件又不能采用,综合了一下网上的资料,个人能力有限,写不出特NB的
代码
来,
代码
很简单,实现了等待
窗体
的功能,对我来说是万事大吉了,现在放出来,分享给有需要的程序猿,再次重点重申,
代码
很简单,没有特别大的含金量,请NB程序猿嘴下留情,找高级的
代码
的话,您就绕道吧,我这个估计不适合您。 demo注意,如果你不打算需改里面的耗时操作,那么你需要在你本地的
SQL
上建立
一个
数据库
TestDB,建立一张表T_ABC,其
中
建立3个
字段
AA、BB、CC,
字段
类型varchar(5),然后修改一下
SQL
连接字符串里的登录帐号密码就能用了,因为我用的是
SQL
2008R2,兼容起来可能是问题,就没放在压缩包里。 本demo肯定不能满足所有人的需要,故不要说一些什么没有研究价值什么的话,我放在这是为了给需要的人解燃眉之急用的,请各位见谅。
SQL
数据库
课程设计(3).doc
学生成绩管理系统设计说明 (本设计以
VB
为前台对
数据库
进行操作) 需
求
本系统主要用于学校的学生成绩管理。 1. 用户身份的验证 2. 学生基本信息管理 3. 按班级选课 4. 学生成绩的管理 总体设计 本系统包括:标准模块、系统登录模块、主界面模块、系统管理模块、学生基本信息 管理模块、选课模块、成绩管理模块。 1. 标准模块 定义公共变量和过程。 2. 系统登录模块 进行用户身份的验证。 3. 主界面模块 作为系统总界面,供用户进行各项选择。 4. 系统管理模块 用户管理及系统退出。 5. 学生基本信息管理模块 学生基本信息的录入和查询。 6. 选课模块 为班级选课。 7. 成绩管理模块 进行学生成绩的录入及查询。
数据库
设计及配置 1
数据库
设计 该
数据库
由以下几个表组成: 用户表、学生基本信息表、班级课程表、学生成绩表。 1 用户表 包括用户名、密码、是否是超级用户。 "
字段
名称 "数据类型 " "用户名 "文本 " "密码 "文本 " "是否为超级用户 "布尔 " 2 学生基本信息表 包括学号、姓名、电话、地址、班级名称、性别。 "
字段
名称 "数据类型 " "学号 "文本 " "姓名 "文本 " "电话 "文本 " "地址 "文本 " "班级名称 "文本 " "性别 "文本 " 3 班级课程表 包括班级名称、课程名称。 "
字段
名称 "数据类型 " "班级名称 "文本 " "课程名称 "文本 " 4 学生成绩表 包括学号、课程名称、成绩。 "
字段
名称 "数据类型 " "学号 "文本 " "课程名称 "文本 " "成绩 "数值(单精度浮点" " "型) " 2
数据库
中
各表关系 学生基本信息表与班级课程表通过班级名称
字段
相关联,学生基本信息表与学生 成绩表通过学号
字段
相关联,班级课程表与学生成绩表通过课程名称
字段
相关联 。 系统实现 1 标准模块(公有模块) 1 标准模块
中
的数据定义 用于定义全局变量及过程。本系统定义了当前用户名及用户类型。 "序号 "变量名 "数据类型 " "1 "UserName "String " "2 "UserType "Boolean " 2 标准模块
代码
设计 Option Explicit Public UserName As String Public UserType As Boolean 2 系统登录模块 1 说明 进行用户身份的验证。特定的用户才能登录到系统。 2
窗体
设计 系统登录
窗体
的
窗体
类型为Form,界面如下图所示: 主要控件属性如下表所示: "对象名 "类型 "属性 "值 "说明 " "FrmLogin"
窗体
"Caption "学生成绩 "学生成绩管理系统登录
窗体
" " " " "管理系统 " " " " " "登录 " " "Label1 "标签 "Caption "用户名: " " "Label2 "标签 "Caption "密码: " " "Text1 "文本框 "Text " "用于输入用户名 " "Text2 "文本框 "Text " "用于输入密码 " "cmdOk "命令按 "Caption "确定 "确定当前输入的用户名和密码 " " "钮 " " ",进行用户登录。登录成功后 " " " " " "进入主界面。如果三次输入错 " " " " " "误的用户和密码,程序将自动 " " " " " "退出 " "cmdCance"命令按 "Caption "取消 "取消操作,退出程序 " "l "钮 " " " " "Adodc1 "Adodc "ConnectionSt" "连接所使用的
数据库
,Connect" " " "ring " "ionString属性在界面
中
设置," " " " " "RecordSource属性在
代码
中
设 " " " " " "置。 " 3
代码
设计 公共定义 Option Explicit Dim Count1 As Integer
窗体
装载处理程序(Load) Private Sub Form_Load() Count1 = 0 '错误次数清零 End Sub 取消按钮(cmdCancel)处理程序(Click) Private Sub cmdCancel_Click() Unload Me '系统退出 End Sub 确定按钮(cmdOk)处理程序(Click) Private Sub cmdOk_Click() Dim s1 As String Dim Password As String On Error Resume Next If Text1.Text = "" Then '用户名为空,则退出 MsgBox ("用户名不能为空,请重新输入") Text1.SetFocus Exit Sub End If '按输
arcgis工具
arcgis工具总结 1. 要素的剪切与延伸 实用工具 TASK 任务栏 Extend/Trim feature 剪切所得内容与你画线的方向有关。 2. 自动捕捉跟踪工具 点击Editor工具栏
中
Snapping来打开Snapping Environment对话框 捕捉设置
中
有3个选项, vertex edge end 分别是节点、终点、和边,选择end应该会捕捉端点 3. 图斑面积计算及长度计算 应用工具CALCULATE AREA 或者使用
VB
A
代码
实现 新建
字段
并开启Advanced 写入
代码
,面积计算: Dim Output as double Dim pArea as Iarea Set pArea = [shape] 在最后的
一个
空格里面写入
代码
(即:
字段
名)pArea.area 长度计算: Dim Output as double Dim pCurve as ICurve Set pCurve = [shape] Output = pCurve.Length 4. 剪切图斑 Task任务栏 cut polygon feature工具,需要sketch工具画线辅助完成 5. 配准工具 Spatial Adjustment 工具 需要注意先要 set adjustment data 然后配准 6. 影像校正 Georeferncing工具 7. 要素变形 Task 工具条
中
的reshape feature 配合sketch工具 8. 添加节点 Modify feature 在需要加点的地方右键单击insert vertex 也可单击右键选择properties 打开edit sketch properties对话框,在坐标点位置右键插入节点 9. 共享多边形生成 Auto-complete polygon 工具生成共享边的多边形,配合snapping environment更好。 10. 画岛图 1).使用任务栏
中
的sketch工具,当画完外面的一圈时,右键 选择finish part 然后画
中
间的部分 再右键finish sketch 2).分别画连个图斑然后应用Editor 工具栏
中
的工具先intersect(图斑重叠的地方创建
一个
新的图斑)然后Clip(剪切)即可。(补充其他工具:Union,把多个图斑联合起来并形成
一个
新的连接在一起的图斑,原图斑无变化,联合后的图斑不继承原任何图斑的属性;Merge,把多个图斑合并到其
中
一个
图斑上并继承它的属性,原图斑变化;Split用于间断线段,但得知道具体的长度,如果不知道那么长度或者没必要那么精确就直接用Eeitor工具栏的Split tool工具 ) 11. 连接外界属性数据(如:.xsl文件等) 利用JOIN 工具可以方便的实现与外界属性数据的关联,但这种关联是依赖于外界
数据库
本身的,需经过重新导出之后即完全保存在相应图层属性页。在做外联如EXCEL等的时候对数据有一些要
求
,确保第一行包含
字段
名,这些
字段
名不能超过十个字母,不能出现特殊字符。最好把EXCEL保存为.csv文件去除一些不兼容的内容再连接。 转载ESRI论坛Lucy1114帖子说明: 12. 导出Shape格式为其他软件识别的打印格式如JEPG等格式 FILE/EXPORT MAP 然后选择相应的
图片
格式,此时也可设置答应的分辨率 pdi 13. 建立注记层 方法一.carvert to Ananotation ,方法二.Draw工具条 方法三.从其他地方转换注记图层 14. 查看特定区域范围内的某种地物分布情况 Selection / select by location 15. 如何用面生成
中
线 先把数据转成coverage格式,workstion里有Centerline命令。 另外ArcToolBox->Data Management Tools->Generalization->Collapse Dual Lines To Centerline也行。不过以上做法要
求
边界是双线。你必须先把面转成线,特别是参数的设置。也可以尝试下sketch工具条
中
的midpoint tool 后面有详细的讲解过程。 16. 根据坐标数据生成点 方法一. :[工具] >>[添加XY 数据],在“添加XY 数据”窗口
中
,选择已添加的 XY 数据表,指定X 坐标
字段
(东经)和Y 坐标
字段
(北纬),按“编辑”按钮,选择坐标系统。一般GPS系统采用的坐标系统为WGS_1984。 方法二.直接用TOOL工具下的ADD XY 可以单个加点 17. 用任意多边形剪切栅格数据(矢量数据转换为栅格数据) 在ArcCatalog下新建
一个
要素类(要素类型为:多边形),命名为:ClipPoly.shp 在ArcMap
中
,加载栅格数据:Landuse、和ClipPoly.shp 打开 编辑器工具栏,开始编辑ClipPoly ,根据要剪切的区域,绘制
一个
任意形状的多 边形。打开属性表,修改多边形的
字段
“ID”的值为1,保存修改,停止编辑。 打开 空间分析工具栏 GIS软件应用-ArcGIS 执行命令:--- 指定栅格大小:查询要剪切的栅格图 层Landuse 的栅格大小,这里指定为25 指定输出栅格的名称为路径 执行命令: - 构造表达式:[Landuse]*[polyClip4-polyclip4] ,执行栅格图层:Landuse 和 用以剪切 的栅格polyClip4 之间的相乘运算 GIS软件应用-ArcGIS 得到的结果即是以任意多边形剪切的Landuse数据 18. 栅格重分类(Raster Reclassify) 通过栅格重分类操作可以将连续栅格数据转换为离散栅格数据 19. Eliminate合并破碎多边形 以下的操作将会把面积小于10000 平方米的多边形合并到周围与之有最长公共 边的多边形
中
: 执行菜单命令[选择]>>[通过属性选择],查询”Area”Masking Tools->Intersecting Layer Masks,为注记创建模版,模版的大小用参数Margin来决定 3).右键点击数据框,在环境菜单
中
选择高级绘制选项(Advanced Drawing Options),用注记的模版图层去遮盖线图层,确定 23.同一图层使用Clip实现图斑的无缝拼接 当
一个
图斑的边界确定,需要实现两个图斑的无缝拼接时,可以把图斑拉伸覆盖确定边界的图斑的一部分,然后用下面的图斑剪区上面的图斑。 方法二:图斑之间有小的缝隙,可以先在缝隙上任意补画
一个
图斑,然后合并(merge)图斑,最后再剪切(Clip)即可得到无缝的图斑。 如下图所示: 24.利用两个相交图斑创建新图斑。 两个图斑都选
中
然后 Eidtor 工具条intersect,此方法原图斑不会被接切。 25.属性表
中
选择集与非选择集的切换 Options/switch selection 26.快速把选择的要素另存为
一个
图层并加载进来。 先选责需要另存图层的要素(直接选择或者属性表),然后在图层上右键Selection/create Layer From Selected Features。 (以前都是直接export竟然没有发现) 27.利用Hyperlinks丰富
数据库
,为其添加超链接。 单击rowse工具栏
中
Identify按钮。 单击地图
中
一个
要素,在Identify Results窗口右击需要设置超链接的要素,然后点击Add Hyperlink菜单。若要将
一个
Web页加为超链接,单击项,并输入URL。要链接到
一个
文档,单击Link to a Document,并输入文档路径名。 单击Tools工具栏
中
的Hyperlink工具,并单击图上某
一个
要素即可实现。 使用
一个
属性
字段
作为超链 在内容表
中
右击包含
一个
超链接
字段
的图层,然后点击properties ,单击Display选项卡。选
中
Supprt Hyper3. Hyperlinks using field选项,单击下拉箭头并点击
一个
字段
。 单击Document or URL。单击OK,单击Tools
中
的Hyperlink按钮,将鼠标指移到一要素上并单击以
显示
其超链接。 28.Arcmap
中
的
SQL
语言 当查询ArcInfo coverages, shape文件, INFO表以及dBASE表时,
SQL
表达式
中
的
字段
名必须用双引号扩起。如:“AREA”,如果查询的是个人地理
数据库
数据,则需要将
字段
名包含在方括号内,如:[AREA],如果查询的是ArcSDE地理
数据库
数据或是ArcIMS要素类或ArcIMS影象服务子层
中
的数据,则不需要将
字段
名括起,如:AREA 有些运算符和关键字也可能有所变化。 在查询表达式
中
,字符串必须加单引号,例如: [STATE_NAME]=‘California’ 除个人地理
数据库
要素类和表之外,查询表达式
中
的字符串是区分字母大小写的。如果搜索不需要区分大小写,可以使用
SQL
函数将所有的值都转换成大写或者小写。对于基于文件的数据源,例如shape文件或coverages,既可以使用UPPER函数,也可以使用LOWER函数。 例如下面这个查询将选出那些姓名的最后为Jones或JONES的顾客。 UPPER("LAST_NAME") = 'JONES' 可以用LIKE运算符(不是 = 运算符)与通配符一起构建部分字符串查询。 例如,表达式 [STATE_NAME] LIKE 'Miss*'将在美国州名
中
选择Mississippi和Missouri。 *表示多个字符。 还比如,查询表达式 [OWNER_NAME] LIKE '?atherine smith' 将找出Catherine Smith和Katherine Smith。 ?表示单个字符。通配符的使用依赖于不同的
数据库
。例子
中
使用的通配符只适用于个人地理
数据库
。 可以使用NULL关键字来选择那些在指定
字段
中
值为NULL的要素和记录。通常,NULL关键字的前面总有IS或IS NOT。 29.Select by location小结 按位置查找要素的方法 使用按位置选择(Select By Location) 对话框,可以根据要素间的相对空间位置进行查找。可以使用多种方法,查找在同一图层
中
或不同图层间相互邻近或叠置的点、线、多边形等要素。 被…跨越边界(Are crossed by the outline of) 利用这种方法,选择被另一图层要素覆盖的某个图层上的要素。例如,搜索道路跨越的荒地,得到的结果是道路跨越其边界的所有荒地。 相交(Intersect) 与Are crossed by the outline of类似,但是该方法可以选择与参照要素接连的要素。例如,选择与道路相交的荒地,选择的结果将包括该道路在其边界范围之内或在其边界之上的所有荒地。 在…距离范围内(Are within a distance of) 这一方法将选择同一图层或不同图层上相邻或邻近的要素。例如,现有
一个
包括清洁井和污染井的图层,使用该方法可以找出距离污染井500米范围内的所有清洁井。同样,也可以找出距离污染井500米范围内其他图层上的水库和农田。还可以用该选项选择与其他要素相毗邻的要素。例如,假如用户已选定了公司可能购买的地块,现在想获取邻近地块的信息。这种情况下,利用该选项选择选
中
地块零距离范围内的所有地块即可。
中
心在…里(Have their center in) 这种方法选择某一图层上的要素,其
中
心点落在另一图层要素
中
。 完全在…内(Are completely within) 这种方法选择完全落在另一图层多边形内部的某一图层上的要素,例如,选择林区里面的湖泊。通过指定
一个
缓冲距离,可以选择落于多边形内部并距离多边形边界一定范围内的所有要素。例如,选择林区内部500米范围内的湖泊。 完全包含(Completely contain) 这种方法选择某一图层上完全包含另一图层上的要素的多边形。例如,选择内部包含湖泊的林区。通过指定
一个
缓冲距离,可以选择在其内部一定范围内包含要素的多边形。例如,对湖泊做缓冲区,可以选择距离湖泊500米范围内的林区。 与…有公共线段(Share a line segment with) 这种方法选择那些与其他要素具有公共线段、顶点或节点的要素。 与…等同(Are identical to) 这种方法选择与另一图层
中
某一要素具有同样几何形状的所有要素。这时,要素类型必须相同。举个例子:必须用多边形选择多边形,用线段选择线段,用点选择点。 包含(Contain) 这种方法选择某一图层
中
包含另一图层
中
要素的要素。这种方法与完全包含(Completely contain)方法的区别在于:要素间的边界可以接触。例如,使用包含(Contain)方法,即使湖泊的边界和包含该湖泊的森林的边界接触,森林也会被选
中
。但是在用完全包含(Completely contain)方法时,森林是不会选
中
的。 包含于(Are Contained by) 这种方法选择某一图层
中
被另一图层
中
要素包含的要素。例如,选择被乡村包围的城市。这种方法和完全包含于(Are completely within)方法的区别在于,要素的边界可以接触。 与…接触(Touch the boundary of) 如果使用包含线的图层来选择要素,则该方法将选择那些与此图层里的线有公共线段,顶点或端点(节点)的线和多边形要素。如果跨越了线,则这些线和多边形将不会被选
中
。 如果使用包含多边形的图层来选择要素,则该方法将选择那些与此图层里的多边形边界有公共线段或顶点的线和多边形要素。如果跨越了多边形边界,则这些线和多边形将不会被选
中
。 31. 将选
中
的要素放大至整个窗口 在内容表
中
右击包含选
中
要素的图层,单击Selection菜单,并单击Zoom To Selected Features子菜单。 选
中
要素将放大至整个ArcMap窗口。 32.
显示
选
中
要素的属性 在内容表
中
右击选
中
要素所在图层,单击Open Attribute Table,单击Show Selected records。 窗口
中
显示
出选
中
要素的属性记录。也可以打开属性表在select和all之间切换。 33. 通过单击要素添加文本 1). 在内容表
中
,右击需要添加标注的图层,单击Properties。 2). 单击Labels选项卡。 3). 单击Label Field下拉箭头,单击作为标注的
字段
。 4). 单击OK。 5). 单击Draw工具条上的Label按钮。 应该是只需单击下拉箭头选择Label按钮。 6). 单击Place label at position clicked。 如果选择了Automatically find best placement,ArcMap会自动的为标注寻找合适的位置。 7). 单击Choose a style,然后单击需要的标注样式。 8). 在需要标注的要素上单击鼠标,标注就添加上去了。 (先在Draw工具条下新建标注组方便管理,New Annotation Group) 34. 标注工具条和标注管理器 如果图层
中
有一些要素需要指定特殊的标注属性,需要在标注管理器
中
生成其它的标注类。 点击左侧面板上的
一个
图层,在右侧面板上为其添加
一个
新的标注类。 个人认为此方法虽然没有转为注记后的标注灵活,但却可以方便的实现自动相对智能化的标注,相比之下更省心,提高效率。 35. 在进行地图查询或编辑的时候为什么会总是选
中
所有的图层 诀窍在这里(虽然是一点点小问题,但当我第一次遇到这个问题时却花费了我不少时间,甚至于怀疑自己的数据有问题) 36.建立拓扑关系检查图斑 先根据需要在Catalog
中
建立相应的拓扑关系规则,然后在Arcmap
中
进行拓扑处理,辅助工具条Topolygon,下图所示为重叠图斑检查。(也可以在Arctoolbox下的Data Management tools/topology来做) 有关geodatabase的topology规则 多边形topology 1).must not overlay:单要素类,多边形要素相互不能重叠 2).must not have gaps:单要素类,连续连接的多边形区域
中
间不能有空白区(非数据区) 3).contains point:多边形+点,多边形要素类的每个要素的边界以内必须包含点层
中
至少
一个
点 4).boundary must be covered by:多边形+线,多边形层的边界与线层重叠(线层可以有非重叠的更多要素) 5).must be covered by feature class of:多边形+多边形,第
一个
多边形层必须被第二个完全覆盖(省与全国的关系) 6).must be covered by:多边形+多边形,第
一个
多边形层必须把第二个完全覆盖(全国与省的关系) 7).must not overlay with:多边形+多边形,两个多边形层的多边形不能存在一对相互覆盖的要素 8).must cover each other:多边形+多边形,两个多边形的要素必须完全重叠 9).area boundary must be covered by boundary of:多边形+多边形,第
一个
多边形的各要素必须为第二个的
一个
或几个多边形完全覆盖 10).must be properly inside polygons:点+多边形,点层的要素必须全部在多边形内 11).must be covered by boundary of:点+多边形,点必须在多边形的边界上 线topology 1).must not have dangle:线,不能有悬挂节点 2).must not have pseudo-node:线,不能有伪节点 3).must not overlay:线,不能有线重合(不同要素间) 4).must not self overlay:线,
一个
要素不能自覆盖 5).must not intersect:线,不能有线交叉(不同要素间) 6).must not self intersect:线,不能有线自交叉 7).must not intersect or touch interrior:线,不能有相交和重叠 8).must be single part:线,
一个
线要素只能由
一个
path组成 9).must not covered with:线+线,两层线不能重叠 10).must be covered by feature class of:线+线,两层线完全重叠 11).endpoint must be covered by:线+点,线层
中
的终点必须和点层的部分(或全部)点重合 12).must be covered by boundary of:线+多边形,线被多边形边界重叠 13).must be covered by endpoint of:点+线,点被线终点完全重合 14).point must be covered by line:点+线,点都在线上 Topology工具条及功能介绍: 37.给多个要素同一赋值 选
中
你需要同一赋值的是所有图斑,然后点击Atrributes,此时出现属性修改对话框,点击根目录是对所有要素同一赋值,点击下面的支目录则可以分别赋值。(也可以用
字段
计算器实现) 38.如何根据确定的点画出以他相应的点 例如:我在地图上已经指导了
一个
一直点,而其他的点在地图上都是以他为
中
心画出来的。学校 SE60度,140米 意思是学校在
中
心点南偏东60度,距离是140米,这样的点在arcmap
中
怎么加呢?我的方法有二分别如下。 1). 确定已有
一个
点图层,其
中
有学校,然后: 对该图层开始编辑 选择工具栏editor---direction-distance tool 以
中
心点为
中
心,先画角度线(arcmap左下角会有角度提示),再画距离/半径(注:画的过程
中
点击A键可以输入角度值,点击D键可以输入距离值) 确定,即可 如果找不到direction-distance tool 的同志请看下面 Direction-distance tool is here 第二种方法就是直接编写
代码
实现 下面是一段示例的
VB
A
代码
(本段
代码
作者:GIS空间站 knight_sl) Option Explicit Dim dPoint(2, 1) As Double Sub aaa() Call bbb Dim aa As IMxDocument Set aa = ThisDocument Dim pFLyr As IFeatureLayer Set pFLyr = aa.FocusMap.Layer(0) Dim pFCsr As IFeatureCursor Dim pFt As IFeature Set pFCsr = pFLyr.FeatureClass.Update(Nothing, False) Set pFt = pFCsr.NextFeature Dim pPoint As IPoint Set pPoint = pFt.ShapeCopy Dim pNewPoint As IPoint Dim X0 As Double, Y0 As Double Dim X As Double, Y As Double Dim dAngle As Double Dim i As Long For i = 0 To UBound(dPoint, 1) Set pFt = pFLyr.FeatureClass.CreateFeature Set pNewPoint = New Point dAngle = dPoint(i, 0) * 3.14159263579893 / 180 pNewPoint.X = dPoint(i, 1) * Cos(dAngle) + pPoint.X pNewPoint.Y = dPoint(i, 1) * Sin(dAngle) + pPoint.Y Set pFt.Shape = pNewPoint pFt.Store Next Set pFLyr = Nothing Set pFCsr = Nothing Set pFt = Nothing Set pPoint = Nothing Set pNewPoint = Nothing End Sub Sub bbb() '定义新加三个点的角度和距离 dPoint(0, 0) = 10 dPoint(0, 1) = 150 dPoint(1, 0) = 30 dPoint(1, 1) = 170 dPoint(2, 0) = 120 dPoint(2, 1) = 200 End Sub 这
中
方法做起来需要一点编程经验,但是比上面那
中
一个
一个
的画的方法要先进多了,可以把所有的点录入同时画出来。 如果你不会
VB
A编程,请看下面: 这是ArcGIS
VB
A的程序,运行的方法: 1),运行ArcMap,加载所需图层; 2),Tools菜单/Macros(宏)/Visual Basic Editor(
VB
编辑器),这样打开
VB
编辑器 3),双击打开
VB
编辑器左上工程资源管理器
中
的Project/ArcMap对象/ThisDocument,把上面的
代码
粘进去。注意看首行 Option Explicit如果有两行,就删除一行。 4),点击
VB
编辑器工具栏的运行按钮运行(或菜单 运行/运行子过程),就可以了,再激活ArcMap可以看到发生了什么! 或者还有一种创建宏的方法(不过建议对ArcGIS
VB
A不大熟的同志不要用这种方法): 1),运行ArcMap,加载所需图层; 2),Tools菜单/Macros(宏)/Macros,这样打开宏编辑器 3),在宏名称
中
输入aaa,确定后,会打开
VB
编辑器,将看到有
一个
aaa的过程,没有实体。你把上面的aaa过程
中
的
代码
粘进去,然后在前面加上 Option Explicit(这个别重复了哈) Dim dPoint(2, 1) As Double 就可以。 4),点击
VB
编辑器工具栏的运行按钮运行(或菜单 运行/运行子过程),就可以了,再激活ArcMap可以看到发生了什么! 39.这里说道了工具的使用,那么就简单的再介绍下Sketch
中
的几个工具吧 Sketch construction tools的使用: Sketch tool:主要是用来创造线和面特征的节点,在你完成了草图之后,ArcMAP就会增加最后的线段,形成矢量图。 Arc tool:这个主要是帮你创造
一个
弧段的,选
中
这个工具后,先在弧段起点点一下,然后在弧段高度方向大致位置点一下(这个点是不可见的,只是给你确定弧段的高度),最后在弧段的终点点一下,就形成一条弧段了。 Direction-distance tool:这个主要是从已知某
一个
方向和某
一个
距离来确定
一个
点。首先点
一个
已知方向的点,这是会有一条线出来,你确定好方向后,再点已知距离的点,这是出来
一个
圆,确定距离后,直线和圆有交点,这就是你要的点,再上面点一下就ok! Distance-distance tool:这个和上面的一样的道理,只是它都用距离来确定
一个
点,也就是两个圆确定你要的点。 Endpoint arc tool:这也是创造弧段用的,与Arc tool 工具不同的是,它是先在弧段的起点点一下,然后在弧段的终点点一下,再点
一个
点确定弧段的半径。个人认为这个工具要比Arc tool工具更精确些。 Intersection tool:就是利用两条直线确定
一个
点。很简单一用就会! Midpoint tool:确定
中
点的工具,比如马路的
中
点,你可以先点一边,再点马路另一边,这时马路的
中
点自动出现了。 (画道路
中
线太可以试试,不过得是直线道路咯,^_^) Tangent tool:相切弧段工具,它能够在一条线段上画出一条切线,只有你用其他工具画了线段出来时你才可以用这个工具。 Trace tool: 主要是用来在跟踪已存在的特征,比如一栋房子,你要沿房子外围画一条线(比如围墙),那么你使用这个工具就非常方便,首先开始时你必须按O键,设置下跟踪的间距,如100,其
中
还有三个角点的方式:mitered是直角 bevelled 是钝角rounded是圆角。(感觉那效果有点像CAD的偏移咯) 40.如何标注多个
字段
的属性及分子式标注 Propertis/label field /expression 实例:""& [单位名称] &"" &
Vb
CrLf & " " & [PARCEL_NO] 输出分数线
Vb
CrLf 换行 效果图: 引用GIS空间站 兔八哥文章详解 以前用ArcGIS Label一般也就在图层的Properties里面定义一下Label字体大小和粗细。这两天遇到
一个
问题,需要在Label
中
显示
多个
字段
的内容,比如BlockName和CompanyName。其实这个本来不是很难的问题,因为Label
中
支持
VB
Script,使用[BlockName] &
Vb
NewLine & [CompanyName]。就可以实现标注
中
第一行
显示
BlockName,第二行
显示
CompanyName. 现在问题出来了,出图时候希望突出BlockName效果,希望加粗
显示
,而CompanyName使用一般字体。考虑了很长时间终于从ArcGIS帮助
中
找到了相关的内容,原来Label的
VB
Script里面支持类似于Html的
VB
Script标签,比如加粗就是用,上面问题就可以使用下面语句解决: "" & [BlockName] & "" &
Vb
NewLine & [CompanyName] 除了加粗,ArcGIS
中
还支持下面的文本格式标签: Font: "" & [LABELFIELD] & "" Color: "" & [LABELFIELD] & "" "" & [LABELFIELD] & "" Bold: "" & [LABELFIELD] & "" Italic: "" & [LABELFIELD] & "" Underline: "" & [LABELFIELD] & "" All caps: "" & [LABELFIELD] & "" Small caps: "" & [LABELFIELD] & "" Superscript "" & [LABELFIELD] & "" Subscript: "" & [LABELFIELD] & "" Character spacing (%): "" & [LABELFIELD] & "" Word spacing (%): "" & [LABELFIELD] & "" Leading (pts): "" & [LABELFIELD] & " nFZLength Then For i=0 To (nFMLength-nFZLength)/2 strLeftSpace =strLeftSpace +chr(32) strRightSpace =strRightSpace + chr(32) Next End If FindLabel = "" &strLeftSpace; & [OBJECTID]&strRightSpace;& ""&chr;(13)&chr;(10)& [SHAPE_Area] End Function 41.用点构面 ArcToolBox->Samples->Data Management->Features->Create Features From Text File 点组成面,最重要的是点序的排列,因此对数据的组织有一定的要
求
。 42.几个常用的
VB
A
代码
在ARCGIS属性表
中
增加需要的
字段
,并自动赋值 使用方法 1打开属性表,选择计算的
字段
,右点选择Calculate Values;2.选择“是”,进入Field Calculator; 2选择Advance选项; 3 在Pre-Logic
VB
A Script Code编辑框
中
输入
VB
A
代码
; 4在下面编辑框
中
输入赋值部分. 1--点坐标X
VB
A部分: Dim pGeo As IGeometry Set pGeo = [Shape] Dim pPoint As IPoint Set pPoint = pGeo 赋值部分: pPoint.X 2--点坐标Y
VB
A部分: 同上 赋值部分: pPoint.Y 坐标值为文件存储的固有值,和是否使用On the Fly坐标表示无关。返回当前
显示
的坐标值参看8,9 3--多边形周长
VB
A部分: Dim pGeo As IGeometry Set pGeo = [Shape] Dim pPolygon As IPolygon Set pPolygon = pGeo 赋值部分: pPolygon.Length 4--多边形面积
VB
A部分: Dim pGeo As IGeometry Set pGeo = [Shape] Dim pPolygon As IPolygon Set pPolygon = pGeo Dim pArea As IArea Set pArea = pPolygon 赋值部分: pArea.Area 5--多边形重心X
VB
A部分: Dim pGeo As IGeometry Set pGeo = [Shape] Dim pPolygon As IPolygon Set pPolygon = pGeo Dim pArea As IArea Set pArea = pPolygon Dim pPoint As IPoint Set pPoint = pArea.Centroid 赋值部分: pPoint.X 6--多边形重心Y
VB
A部分: 同上 赋值部分: pPoint.Y 7--Polyline长度
VB
A部分: Dim pGeo As IGeometry Set pGeo = [Shape] Dim pPolyline As IPolyline Set pPolyline = pGeo Dim pCurve As IPolycurve Set pCurve = pPolyline 赋值部分: pCurve.Length 8--表示点坐标X
VB
A部分: Dim pDoc As IMxDocument Set pDoc = ThisDocument Dim pSpRef As ISpatialReference Set pSpRef = pDoc.FocusMap.SpatialReference Dim pClone As IClone Set pClone = [Shape] Dim pGeo As IGeometry Set pGeo = pClone.Clone Dim pPoint as IPoint Set pPoint = pGeo pGeo.Project pSpRef 赋值部分: pPoint.X 9--表示点坐标Y
VB
A部分: 同上 赋值部分: pPoint.Y 坐标值为On the Fly
显示
的坐标,不是文件存储的固有坐标 10--连续编号
VB
A部分: Static lCount as long lCount=lCount+1 赋值部分: lCount (从1开始) lCount-1 (从0开始) 计算面的
中
点 Dim Output As Double Dim pArea As IArea Set pArea = [Shape] Output = pArea.Centroid.X(或y) 当然这是很老的方法了,现在arcgis9.2以后都不需要用
VB
A啦,右键属性表
字段
然后直接选择 Caculate Geometry就可以实现比如面积计算,X,Y坐标等的属性赋值了咯。 43. 在同一图层如何对同一要素的不同部分以不同的符号表示 (注:要实现这种渲染需要两段具有不同的属性) 44.自己做arcMAP的图例 在Symbol property Editor
中
进行制作了 1)、先在Style Manager
中
的左侧列表
中
,选择相应的Style文件,ArcGIS默认的符号库文件是ESRI.Style文件,当然也给出了C:\Documents and Settings\........................................目录下用于用户自定义的Style文件 2)、展开Style文件,选择要创建Symbol的类型,如:Fill Symbol(面填充)、Line Symbol(线)、Marker Symbol(点) 然后在右侧的列表
中
鼠标右键->New 3)、在弹出的Symbol Property Editor
窗体
中
,进一步选择Marker Symbol的类型,如:Simple Marker Symbol、Picture Marker Symbol等等 4)、这个时候就要根据需要开始设计符号的各种属性了,由于不同种类的Marker Symbol有不同的属性,因此,属性也会不尽相同。 5)、另外介绍
一个
经常需要或比较使用的步骤,我们需要设计的符号可以由ESRI提供的现有符号组合而成,那么我们则需要添加2个Symbol Layer,然后进行2个Symbol Layer的叠加 6)、分别设置上述2个Symbol Layer的
中
的Symbol的属性,之后确认保存,这样会在Style Manager
中
看到我们新制作的符号 如图: (注:以上内容转载自ESRI社区 gis27) 45.计算属性
中
相同的
字段
个数 选择要计算的
字段
然后右键选择Summarize根据相应的要
求
设置参数即可实现。功能示意如下图: 46.自动提取面的
中
点并加点 Arctoolbox->Feature-> Feature to Point 47.合并属性相同的相邻图斑 使用Dissolve 当选择了create multipart feature时,所有具有相同属性的图斑将链接在一起做为
一个
图斑。 48.提取图斑转折点坐标 如果没有伪节点那么,选
中
一个
线或者面,打开sketch Properties,就可以看到节点坐标。 还有一种方法就是:通过toolbox-datamanagement-feature-FeatureVerticesToPoints得到转折点的图层然后Add XY Coordinates,该点图层的属性表
中
就包含了X,Y
字段
,将其导出,就得到转折点坐标了。 ArcMap
中
设置.mxd相对路径 复制拷贝地图文档后再次打开会遇到图层前
一个
!的标识符号,是因为加载图层的相对路径变化了,需要重新指定图层位置。对此将.mxd文档设置为相对路径起到作用,具体做法如下: (1)File-->Document Properties-->打开对话框
中
,点击Data Source Options...按钮; (2)选
中
store relative path names to data sources单选框,并勾选Make relative paths the defalut of...前的复选框。 以上两步操作即可。 在dissolve时,出现 ERROR 000354: The name contains invalid characters Failed to execute (Dissolve). End Time: Thu Mar 24 09:32:47 2011 (Elapsed Time: 0.00 seconds) output文件包括无效字符如
中
划线等 Geometry First [Editor's note: I was having trouble last week dissolving a shapefile based on a common attribute. I kept getting the following error: "Invalid Topology [INCOMPLETE_VOID_POLY]“. Not entirely helpful! A little Google searching turned up the following tip from ESRI.] Republished from ESRI. Problem: Some Overlay Tools, such as Intersect, return unexpected results or fail Description Results do not look correct or operations fail with strange errors such as: “Invalid Topology [INCOMPLETE_VOID_POLY]“. If this type of error has occurred, it is most likely to occur when using one of the following: Clip, Erase, Identity, Intersect, Symmetrical Difference, Union, Update, Split Featureclass to Coverage, Dissolve, Feature to Line, Feature To Polygon, Integrate, or ValidateTopology. Cause It is possible that tool outputs may be strange or incorrect because one or more features in the input feature class have geometry problems. Some examples of geometry problems are: • short segments • null geometry • incorrect ring ordering • incorrect segment orientation • unclosed rings • self-intersections or empty parts Solution or Workaround If such errors occur or the output looks incorrect, the first step in assessing the situation is to run the ArcToolbox tool Data Management Tools > Features > Check Geometry. -show me This tool provides a list of the invalid features in the feature class and a short description of the problem. Features with problems can be fixed in one of two ways: Editing the feature class with the geometry problem, and fixing each individual problem identified. Some of these problems, like non-simple geometry, can be fixed by double-clicking the feature in the editor and saving the edits. Running the ArcToolBox tool Data Management Tools > Features > Repair Geometry on the feature class containing the problem features 昨天检查一区属性发现一区图层的面积属性shape_area竟然出现了负值,想必是数据转换的时候出现了问题。今天在论坛
求
证了一下,感谢各位的解答。 ArcGIS默认顺时针图形为正,手工画polygon的时候不管怎么画结果都是顺时针的。所以一般负值的出现是转换过程出现问题,polygon是由ring组成的,ring则是有更小的segement(line,circularArc,ellipticalArc,beziercurve)构成,所具有方向性。 解决方法是用ArcTool
中
的check geometry和 repair geometry工具,上述的检查结果是Incorrect ring ordering。repair后会自动修复错误,已解决。 此外,repair工具只能修复以下五种错误: Null geometry—The feature will be deleted from the feature class. Short segment—The geometry's short segment will be deleted. Incorrect ring ordering—The geometry will be updated to have correct ring ordering. Incorrect segment orientation—The geometry will be updated to have correct segment orientation. Self intersections—The geometry's segments that intersect will be split at their intersection. Unclosed rings—The unclosed rings will be closed. Empty parts—The parts that are null or empty will be deleted. 更多的错误修复参照帮助
中
的 How to salvage a corrupt shapefile
Access 2007
VB
A宝典 1/4
完整清晰版 PDF ,有目录。共 120MB,分为四个分卷 Access 2007
VB
A宝典 作者:(美)费德玛(Feddema,H.) 著,张波,陈江红,苏丽译 出版社:人民邮电出版社 出版日期:2008-6-1 ISBN:9787115175984 字数:843000 页数:473 -------------------------------------------------------------------------------- 使用
VB
A
代码
链接Office应用程序 同步Access和Outlook联系人 简化任务并提高生产率。 充分利用Access 2007的全部功能 充分利用Access 2007的全部功能 在各个Microsoft Office应用程序之间无缝地传递Access数据,这只是针对初学者。在这本由知名AcceSS专家HeIen Feddema撰写的全新并且全面的指南
中
。您可以学习编写Vi-sual Basic
代码
,从而自动执行Access
数据库
任务、创建独立脚本、提取及合并数据,而且可以将各种强大的解决方案结合起来,从而提高在Office家族成员间工作时的效率。无论您是初学者还是有经验的用户,本书都是您成功驾驭Access 2007 的必备书籍。 ·在Word、Excel和Outlook之间操作并共享Access数据: ·从Access创建Word文档; ·编写
VB
A
代码
来自动执行
数据库
任务; ·创建Access
窗体
,作为数据交换的控制面板: ·使用COM和Access加载项添加功能; ·使用
SQL
Server数据: ·使用XML自定义Access 2007功能区。 在各个Microsoft Office应用程序之间无缝地传递Access数据,这只是针对初学者。在这本由知名Access专家Helen Feddema撰写的全新并且全面的指南
中
,您可以学习编写Visual Basic
代码
。从而自动执行Access
数据库
任务、创建独立脚本、提取及合并数据,而且可以将各种强大的解决方案结合起来,从而提高在Office家族成员间工作时的效率。无论您是初学者还是有经验的用户。本书都是您成功驾驭Access 2007的必备书籍。 内容提要 -------------------------------------------------------------------------------- Access是Microsoft公司Office办公套件
中
的
数据库
应用程序,而Access
VB
A是Access的编程语言。利用
VB
A不仅能够设计常用的小工具、小软件,还能够编写
代码
,让很多程序共享数据。本书全面介绍了Access
VB
A的应用。首先介绍各种Office组件及其用途,然后详细介绍了这些组件,以及如何在组件之间共享各种数据;最后介绍了更为高级的主题,包括
VB
6.0、Access加载项、Visual Studio 2005共享加载项、使用XML实现自定义Office 2007功能区,以及与
SQL
Server
数据库
的交互等。 本书内容丰富,并且在配套网站上提供了书
中
所有的示例文件和
代码
,有助于读者通过亲身实践掌握Access
VB
A的强大功能。本书适合Office的
中
高级用户以及希望学习Access
VB
A的人员参考。 目录 -------------------------------------------------------------------------------- 第1部分 Office组件及其最佳用途 第1章 在Access
中
存储和
显示
数据 1.1 Office数据交换简史 1.2 在Access
中
存储数据 1.3 在Access
窗体
和报表
中
显示
数据 1.3.1 创建Access套用信函 1.3.2 在Access
中
创建工作表类型的报表 1.4 小结 第2章 从Access
中
创建Word文档 2.1 使用TypeText.方法为Word文档填充Access数据 2.2 使用Word模板创建格式化的Word文档 2.2.1 书签 2.2.2 文档属性 2.3
窗体
域文档 2.4 小结 第3章 使用Excel分析数据 3.1 将Access数据导出到未格式化的工作表 3.2 使用Excel模板创建填充了Access数据的格式化工作表 3.3 使用
VB
A
代码
对Excel工作表进行格式化 3.4 小结 第4章 使用Outlook进行组织和通信 4.1 将约会和任务导出到Outlook 4.2 将日记信息导出到Ou
数据库(包含打印,安装,报表)
1,216
社区成员
55,954
社区内容
发帖
与我相关
我的任务
数据库(包含打印,安装,报表)
VB 数据库(包含打印,安装,报表)
复制链接
扫一扫
分享
社区描述
VB 数据库(包含打印,安装,报表)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章