- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个套接字客户端应用程序。
应用程序非常简单,Activty启动一个新的套接字线程来连接服务器。线程从服务器接收命令并通过setImageDrawable更改ImageView。
布局中只有一个ImageView。 socket线程将使用BufferedReader从服务器获取命令,它的命令行是“start”,socket线程将向主 Activity 发送消息以执行setImageDrawable。
这是我的问题:在肖像模式下一切正常。但在横向模式下不起作用。
打击的是布局:
package com.example.whiletest;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.SocketTimeoutException;
import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.widget.ImageView;
import android.widget.TextView;
public class WhileTest extends Activity {
private ImageView ivTest;
private TextView tvState;
private Handler handler = null;
private String strTemp;
private Message message=new Message();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
/* set app to LANDSCAPE mode */
this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
setContentView(R.layout.activity_while_test);
tvState = (TextView) findViewById(R.id.textView1);
ivTest = (ImageView) findViewById(R.id.imageView1);
/* Change UI by main activity*/
handler = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case 110:
ivTest.setImageDrawable(getResources().getDrawable(R.drawable.btn_camera_recording));
ivTest.postInvalidate();
System.out.println("OKAYAYHHAHS");
break;
case 112:
tvState.setText("收到指令 = " + strTemp);
break;
}
super.handleMessage(msg);
}
};
new Thread(){
@Override
public void run()
{
Socket socketNet;
try{
socketNet = new Socket("192.168.2.104",3302); //make connection
System.out.println("Connected!!!");
BufferedReader bff=new BufferedReader(new InputStreamReader(socketNet.getInputStream()));
PrintWriter os=new PrintWriter(socketNet.getOutputStream());
while ((strTemp = bff.readLine()) != null){
//got command from server then send message to main activity
System.out.println("readLine = " + strTemp);
message.what=112;
handler.sendMessage(message);
if( strTemp.equals("start")){
message.what=110;
handler.sendMessage(message);
}
};
} catch (SocketTimeoutException aa) {
System.out.println("TimeOut");
}catch (Exception e){
e.printStackTrace();
}
}
}.start();
}
}
下面是布局
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.whiletest.WhileTest" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world" />
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:layout_marginRight="138dp"
android:layout_marginTop="163dp"
android:src="@drawable/ic_launcher" />
</RelativeLayout>
这是server.java
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Timer;
import java.util.TimerTask;
public class Server{
public static void main(String args[]) {
try{
ServerSocket server=null;
try{
server=new ServerSocket(3302);
}catch(Exception e) {
System.out.println("can not listen to:"+e);
}
Socket socket=null;
try{
socket=server.accept();
System.out.println("accepted.");
}catch(Exception e) {
System.out.println("Error."+e);
}
String line="start";
BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
final PrintWriter os=new PrintWriter(socket.getOutputStream());
Timer timer=new Timer();
timer.schedule(new TimerTask(){
public void run() {
os.println("start");
os.flush();
//System.out.println("Command Sended" + String.valueOf(System.currentTimeMillis()));
}
} , 1000, 1000);
}catch(Exception e){
System.out.println("Error:"+e);
}
}
}
我已经为此工作了三天。请帮助我。
最佳答案
尝试在 list 文件中您所在的 Activity 下添加此行:
android:configChanges="orientation|screenSize"
关于java - ImageView.setImageDrawable 在 LANDSCAPE 模式下不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27085561/
对此感到疯狂,真的缺少一些东西。 我有webpack 4.6.0,webpack-cli ^ 2.1.2,所以是最新的。 在文档(https://webpack.js.org/concepts/mod
object Host "os.google.com" { import "windows" address = "linux.google.com" groups = ["linux"] } obj
每当我安装我的应用程序时,我都可以将数据库从 Assets 文件夹复制到 /data/data/packagename/databases/ .到此为止,应用程序工作得很好。 但 10 或 15 秒后
我在 cc 模式缓冲区中使用 hideshow.el 来折叠我不查看的文件部分。 如果能够在 XML 文档中做到这一点就好了。我使用 emacs 22.2.1 和内置的 sgml-mode 进行 xm
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
根据java: public Scanner useDelimiter(String pattern) Sets this scanner's delimiting pattern to a patt
我读过一些关于 PRG 模式以及它如何防止用户重新提交表单的文章。比如this post有一张不错的图: 我能理解为什么在收到 2xx 后用户刷新页面时不会发生表单提交。但我仍然想知道: (1) 如果
看看下面的图片,您可能会清楚地看到这一点。 那么如何在带有其他一些 View 的简单屏幕中实现没有任何弹出/对话框/模式的微调器日期选择器? 我在整个网络上进行了谷歌搜索,但没有找到与之相关的任何合适
我不知道该怎么做,我一直遇到问题。 以下是代码: rows = int(input()) for i in range(1,rows): for j in range(1,i+1):
我想为重写创建一个正则表达式。 将所有请求重写为 index.php(不需要匹配),它不是以/api 开头,或者不是以('.html',或'.js'或'.css'或'.png'结束) 我的例子还是这样
MVC模式代表 Model-View-Controller(模型-视图-控制器) 模式 MVC模式用于应用程序的分层开发 Model(模型) - 模型代表一个存取数据的对象或 JAVA PO
我想为组织模式创建一个 RDF 模式世界。您可能知道,组织模式文档基于层次结构大纲,其中标题是主要的分组实体。 * March auxiliary :PROPERTIES: :HLEVEL: 1 :E
我正在编写一个可以从文件中读取 JSON 数据的软件。该文件包含“person”——一个值为对象数组的对象。我打算使用 JSON 模式验证库来验证内容,而不是自己编写代码。符合代表以下数据的 JSON
假设我有 4 张 table 人 公司 团体 和 账单 现在bills/persons和bills/companys和bills/groups之间是多对多的关系。 我看到了 4 种可能的 sql 模式
假设您有这样的文档: doc1: id:1 text: ... references: Journal1, 2013, pag 123 references: Journal2, 2014,
我有这个架构。它检查评论,目前工作正常。 var schema = { id: '', type: 'object', additionalProperties: false, pro
这可能很简单,但有人可以解释为什么以下模式匹配不明智吗?它说其他规则,例如1, 0, _ 永远不会匹配。 let matchTest(n : int) = let ran = new Rand
我有以下选择序列作为 XML 模式的一部分。理想情况下,我想要一个序列: 来自 my:namespace 的元素必须严格解析。 来自任何其他命名空间的元素,不包括 ##targetNamespace和
我希望编写一个 json 模式来涵盖这个(简化的)示例 { "errorMessage": "", "nbRunningQueries": 0, "isError": Fals
首先,我是 f# 的新手,所以也许答案很明显,但我没有看到。所以我有一些带有 id 和值的元组。我知道我正在寻找的 id,我想从我传入的三个元组中选择正确的元组。我打算用两个 match 语句来做到这
我是一名优秀的程序员,十分优秀!