
你可
以这样设置下: 自己写一个 缓存类,用于保存用户第一次从数据库读取出来的数据,当第2次进来的时候,先把这个缓存数据赋值上去,同时判断网络上的数据有没有更新,在刷到这个页面,同时并更新数据库!这样比每次都从数据库都取效果要好些!
2014-05-19
摘 要 本文以VB6与Access97作为开发工具,介绍了图像在数据库中的存储与显示技术。
关键词 数据库,数据控件,二进制,图像存储,图像显示,ADODB,Recordset
数据库是数据管理的最新技术,是计算机科学的重要分支,是现代计算机信息系统和计算机应用的基础和核心。在科学技术高速发展的今天,在信息资源无处不在、无处不用,已成为各部门的重要财富的时候,对于从事程序开发的人员来说显得尤为重要。
如今,对数据库的 *** 作不仅仅满足于对字符和数字的单一 *** 作,图像的存储与显示已显得尤为重要。下面作者将以VB60与Access97作为开发工具,分别介绍两种图像显示与存储的方法。
利用数据控件和数据绑定控件
利用这种方法,不写或写少量代码就可以构造简单的数据库应用程序,这种方法易于被初学者接受。在举例之前,先把数据绑定功能简要的说明一下,凡是具有DataSource属性的控件都是对数据敏感的,它们都能通过数据控件直接使用数据库里的数据。比如CheckBox Control , ComboBox Comtrol , TextBox Comtrol , PictureBox Control ,Image Comtrol … 因为这种方式涉及到的知识点比较少,也比较容易理解,不多作说明,现直接介绍编程步骤。
1、从数据库中显示所需要的
首先,添加一个Data数据控件,设置它的DatabaseName和RecordSource属性,
strPath = AppPath
If Right(strPath, 1) <> "\" Then
strPath = strPath & "\"
MyDataDatabaseName = strPath & "ExampleDBmdb" '数据库存地址
MyDataRecordSource = "Info" '表名
第二步,添加Image控件用来显示,设置它的DataSource和DataField属性。例如本例中: Image1DataSource="MyData"和Image1DataField=" MyPhoto" 。然后设置其它具有数据绑定功能的控件用来显示所要的其它内容,经过这两步的 *** 作,运行程序就可以显示你要的数据了。
2、向数据库中添加需要存储的
首先,利用数据控件所具有的AddNew属性,添加一个按钮,双击后添加如下代码MyDataRecordsetAddNew
第二步,为Image控件指定路径Image1Picture = LoadPicture("路径"),经过这两步的 *** 作,就可以向数据库中添加了。
这种方法最简单快捷,要写的代码量很少。但是这种方法在运行速度和灵活性方面有一定的限制,适合于初学者和一些简单的应用,要想灵活多变的显示图像,下面介绍的方法或许更适应您的要求。
利用编写代码实现的存储与显示
这种方法相对于方法一来说,代码量大,但是它 *** 作灵活,能够满足多样形式下的 *** 作,受到更多编程者的青睐。但是涉及到的知识面相对要多一些,不仅要掌握数据库的 *** 作方法,还要二进制文件的读写作进一步的了解。关于数据库及二进制文件的基本 *** 作很多参考书上都介绍的比较详细,需要时请查阅即可。在编程之前把本部分用到的变量说明如下:
Dim RS As New ADODBRecordset
Dim Chunk() As Byte
Const ChunkSize As Integer = 2384
Dim DataFile As Integer, Chunks, Fragment As Integer
Dim MediaTemp As String
Dim lngOffset, lngTotalSize As Long
Dim i As Integer
1、从数据库中显示所需要的
第一步首先打开数据库,看有没有要查找的内容,有则继续执行,没有就退出
RSSource = "select from Info Where Name='" & sparaName &"';"
RSActiveConnection = "UID=;PWD=;DSN=TestDB;"
RSOpen
If RSEOF Then RScCose : Exit Sub
第二步,读出长二进制数据即数据,把它转换成文件, *** 作过程如下
MediaTemp = strPath & "picturetemptmp"
DataFile = 1
Open MediaTemp For Binary Access Write As DataFile
lngTotalSize = RS!MyPhotoActualSize
Chunks = lngTotalSize \ ChunkSize
Fragment = lngTotalSize Mod ChunkSize
ReDim Chunk(Fragment)
Chunk() = RS!MyPhotoGetChunk(Fragment)
Put DataFile, , Chunk()
For i = 1 To Chunks
ReDim Chunk(ChunkSize)
Chunk() = RS!MyPhotoGetChunk(ChunkSize)
Put DataFile, , Chunk()
Next i
Close DataFile
第三步,关闭数据库,这样就可以显示所要的了。
RSClose
If MediaTemp = "" Then Exit Sub
Picture1Picture = LoadPicture(MediaTemp)
If Picture1Picture = 0 Then Exit Subj
2、向数据库中添加需要存储的
向数据库添加存储的是显示逆过程,只要掌握了显示的 *** 作,存储的 *** 作也就迎刃而解了,下面将 *** 作步骤介绍如下
第一步首先打开数据库,过程如下:
RSSource = "select from Info ;"
RSCursorType = adOpenKeyset
RSLockType = adLockOptimistic
RSActiveConnection = "UID=;PWD=;DSN=TestDB;"
RSOpen
第二步,把要存储的转换成二进制长文件存入数据库中, *** 作过程如下
RSAddNew
DataFile = 1
Open strPathPicture For Binary Access Read As DataFile
FileLen = LOF(DataFile) ' 文件中数据长度
If FileLen = 0 Then : Close DataFile : RSClose : Exit Sub
Chunks = FileLen \ ChunkSize
Fragment = FileLen Mod ChunkSize
ReDim Chunk(Fragment)
Get DataFile, , Chunk()
RS!MyPhotoAppendChunk Chunk()
ReDim Chunk(ChunkSize)
For i = 1 To Chunks
Get DataFile, , Chunk()
RS!MyPhotoAppendChunk Chunk()
Next i
Close DataFile
第三步,更新纪录后,关闭数据库,就完成了数据到数据库的存储。
RSUpdate
RSClose
Set RS = Nothing
两种方法在使用方面各有所长,读者可以针对自己的情况做出合理的选择。
方法很容易实现的.和楼上的不太一样.
Loader API让你从ContentProvider或者其他数据源读取数据展示在FragmentActivity或者Fragment上。如果你不理解你为什么要用Loader API执行看似平凡的 *** 作,那么首先要考虑没有loader的情况下可能遇到这些问题:
Loader解决了这些问题,包括其他好处。例如:
在app中使用Loader是可能涉及多个类和接口。
一个与FragmentActivity和Fragment相关的抽象类,管理一个或多个Loader实例。 每个activity或fragment中只有一个LoaderManager,但是一个LoaderManager能管理多个Loader。
Loader调用initLoader()或restartLoader()开始读取数据。系统自动确定具有相同ID的Loader是否存在,并将创建新的Loader或者重新使用现用的Loader。
这个接口包含回调Loader事件触发时回调的方法。接口定义三个回调方法:
此接口通常通过activity或fragment实现并注册,当调用initLoader()或restartLoader()。
Loader执行加载数据。该类是一个抽象的,作为基础类服务与所有Loader。你可以直接使用子类Loeader或者使用内置子类之一来简单实现。
app使用Loader通常包括以下内容:
一个FragmentActivity或Fragmentyou只有一个LoaderManager管理一个或多个Loader实例。通常在Activity的onCreate()方法或者在fragment的onActivityCreateed()方法中初始化Loader,如下:
initLoader()方法参数如下:
initLoader()调用确保Loader被初始化和活跃。他有两种可能:
在任何一种情况下,给的LoaderManagerLoaderCallbacks实现都与Loader相关联,在Loader状态改变时被调用。如果调用的时候调用者处于开始状态,请求已经存在的Loader并生成了它的数据,系统会立马调用onLoadFinished()方法(在iniLoader()之间),你必须准备好这些的发生。
注意initLoader()方法返回的被创建Loader,但是你不需要捕获它的引用。Loadermanager自动管理Loader的生命周期。必要时LoaderManager开始和停止加载数据,可以维持Loader相关内容的状态。这意味着,你很少和Loader直接交互(尽管使用Loader方法来微调Loader的行为)。
当你使用initLoader(),如上所示,如果ID指定的Loader已经存在,用这个。如果不是就创建一个。但是有时候你想丢弃老数据并重新开始。
要丢弃你的老数据,你用restartLoader()。例如,当用得查询队列变更时,这个SearchViewOnQueryTextListenerde实现会重启Loader。Loader需要重启,以便接受搜索过滤器做一次新的查询:
LoaderManagerLoaderCallbacks是一个回调接口,让客户端通过LoaderManager与之交互。
CursorLoader预计Loader在停止之后将保留其数据。允许应用保持activity或fragment的onStop()和onStart()方法相关的数据,当用户返回应用程序时他们不必等待数据重载。你可以再LoaderManagerLoaderCallbacks方法合适使用这些方法创建一个新的Loader,并告诉应用合适停止使用Loader的数据。
当你试图访问一个Loader(例如通过initLoader())时,它会检查该ID指定的Loader是否存在。如果没有,则触发LoaderManagerLoaderCallbacks的onCreateLoader()方法。这是你创建一个新的Loader的地方。通常将是CursorLoader(),但你能实现Loader的子类。
在这个例子中,onCreateLoader()回调方法创建一个CursorLoader。你必须用CursorLoader的构造方法创建CursorLoader,这需要完整地信息集来执行查询ContentProvider。具体来说,它需要:
例如:
当之前创建的Loader已经完成加载时此方法被调用。这个方法保证Loader提供最后的数据之前被调用。此时,你应该移除所有的老数据(因为它很快被释放),但是不应该你自己释放数据,因为它的Loader拥有它并会照顾。
一旦应用长时间不使用loader将释放数据。例如,如果数据是来自CursorLoader的一个cursor,你不应该自己调用close()。如果cursor放在CursorAdapter中,你应该用swapCursor()方法这样老的cursor不关闭。例如:
当已经创建的Loader正在重置是调用这个方法,从而使数据不可用。这个回调让你找出数据何时被释放,这样你就可以移除它的引用。
作为一个例子,这里实现了一个完整地Fragment显示一个LIstView,包含ContentProvider查询联系人内容的查询结果。它使用了CursorLoader管理provider的查询。
对于访问用户联系人的应用,如本例所示,manifest必须包含READ_CONTACTS权限。
以下示例说明如何使用装载机:
bmob后台提供数据服务,可以直接建表,你把数据库逻辑设计好,可以先建表 然后网站页面写好之后调用bmobsdk就能使用了, 服务器什么的也不用自己配置,后端就接上去能用了,就是这样
首先 有个xml布局如下:
<RelativeLayout xmlns:android=">
xmlns:tools=">
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="comexamplefourtothreetestMainActivity" >
<TextView
android:id="@+id/title"
android:layout_width="match_parent"
android:layout_height="50dp"
android:layout_alignParentTop="true"
android:background="@color/rednocheck"
android:gravity="center"
android:text="点餐系统"
android:textColor="@color/redcheck"
android:textSize="20sp" />
<RadioGroup
android:id="@+id/rad"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:checkedButton="@+id/fuwugengxin"
android:orientation="horizontal" >
<RadioButton
android:id="@+id/laikedengji"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_weight="1"
android:background="@drawable/redselect"
android:button="@null"
android:gravity="center"
android:onClick="onclick"
android:text="来客登记"
android:textColor="@color/blacklight" />
<RadioButton
android:id="@+id/kaishidiancan"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_weight="1"
android:background="@drawable/redselect"
android:button="@null"
android:gravity="center"
android:onClick="onclick"
android:text="开始点餐"
android:textColor="@color/blacklight" />
<RadioButton
android:id="@+id/yidiancaidan"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_weight="1"
android:background="@drawable/redselect"
android:button="@null"
android:gravity="center"
android:onClick="onclick"
android:text="以点菜单"
android:textColor="@color/blacklight" />
<RadioButton
android:id="@+id/fuwugengxin"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_weight="1"
android:background="@drawable/redselect"
android:button="@null"
android:gravity="center"
android:onClick="onclick"
android:text="服务更新"
android:textColor="@color/blacklight" />
</RadioGroup>
<FrameLayout
android:id="@+id/fmalay"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@+id/rad"
android:layout_below="@+id/title"
android:background="#000000" >
</FrameLayout>
</RelativeLayout>
其次:主activity
package comexamplefourtothreetest;import androidappActivity;
import androidappFragment;
import androidappFragmentManager;
import androidappFragmentTransaction;
import androidosBundle;
import androidviewMenu;
import androidviewMenuItem;
import androidviewView;
import androidwidgetRadioButton;
public class MainActivity extends Activity {
static FragmentManager manger;
public static RadioButton kaishidian;
@Override
protected void onCreate(Bundle savedInstanceState) {
superonCreate(savedInstanceState);
setContentView(Rlayoutactivity_main);
kaishidian = (RadioButton) findViewById(Ridkaishidiancan);
manger = getFragmentManager();
change(new FuWuGengXin());
}
public static void change(Fragment fragment) {
FragmentTransaction fragmentTransaction = mangerbeginTransaction();
fragmentTransactionreplace(Ridfmalay, fragment);
fragmentTransactioncommit();
}
public static void sw() {
change(new KaiShiDianCan());
kaishidiansetChecked(true);
}
public void onclick(View v) {
switch (vgetId()) {
case Ridlaikedengji: {
change(new LaiKeDengJi());
}
break;
case Ridkaishidiancan: {
change(new KaiShiDianCan());
}
break;
case Ridyidiancaidan: {
change(new YiDianCaiDan());
}
break;
case Ridfuwugengxin: {
change(new FuWuGengXin());
}
break;
default:
break;
}
}
}
最后每个新页面都有一个activity:
package comexamplefourtothreetest;
import javautilArrayList;
import androidappFragment;
import androidcontentSharedPreferences;
import androidcontentSharedPreferencesEditor;
import androidosBundle;
import androidpreferencePreferenceManager;
import androidviewLayoutInflater;
import androidviewView;
import androidviewViewOnClickListener;
import androidviewViewGroup;
import androidwidgetArrayAdapter;
import androidwidgetButton;
import androidwidgetEditText;
import androidwidgetSpinner;
public class LaiKeDengJi extends Fragment {
private View v;
private Spinner spr;
private EditText expeople, exgonghao;
private Button btnstart;
private SharedPreferences pre;
Editor editor;
private String[] items = { "1号", "2号", "3号", "4号", "5号", "6号", "7号", "8号",
"9号" };
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
v = inflaterinflate(Rlayouttab_laikedengji, null);
spr = (Spinner) vfindViewById(Ridspr);
expeople = (EditText) vfindViewById(Ridexpeople);
exgonghao = (EditText) vfindViewById(Ridexgonghao);
btnstart = (Button) vfindViewById(Ridbtn_start);
btnstartsetOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
MainActivitysw();
}
});
pre = PreferenceManagergetDefaultSharedPreferences(AppOsappos);
editor = preedit();
ArrayList<String> list = new ArrayList<String>();
for (int i = 0; i < itemslength; i++)
{
listadd(items[i]);
}
ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(),
androidRlayoutsimple_spinner_dropdown_item, list);
sprsetAdapter(adapter);
if (pregetInt("first", 0) == 0) {
create();
}
// create();
editorputInt("first", 1);
editorcommit();
return v;
}
public void init() {
}
/
创建数据库
/
public void create() {
String dbstr_cai, dbstr_zhuo, dbstr_yongcan, dbstr_yidian;
DbHelper dbHelper;
dbstr_cai = "create table caidan (id varchar(50),name varchar(50),price number,image varchar(100))";
dbstr_zhuo = "create table zhuodan (id varchar(50),name varchar(50))";
dbstr_yongcan = "create table yongcandan (id varchar(50),personnum number,tid varchar(50),staffno varchar(50),pdatetime datetime)";
dbstr_yidian = "create table yidiancaidan (id varchar(50),oid varchar(50),fid varchar(50),num number)";
dbHelper = new DbHelper();
dbHelpercreate(dbstr_cai);
dbHelpercreate(dbstr_zhuo);
dbHelpercreate(dbstr_yongcan);
dbHelpercreate(dbstr_yidian);
}
}
然后每个界面都有你需要的布局就行了,这个例子是4个界面跳转的,小编只能帮你到这了
以上就是关于Fragment刷新界面应该怎么 *** 作全部的内容,包括:Fragment刷新界面应该怎么 *** 作、如何将数据库中的图片(二进制),读出并显示在界面的Image控件[VB6.0]、Android Loader官方使用说明等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)